Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hwholiday/short_url
短链接生成器
https://github.com/hwholiday/short_url
gin mysql redis shorturl
Last synced: about 2 months ago
JSON representation
短链接生成器
- Host: GitHub
- URL: https://github.com/hwholiday/short_url
- Owner: hwholiday
- Created: 2019-07-02T09:44:55.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-09-08T02:32:05.000Z (over 2 years ago)
- Last Synced: 2024-10-12T04:07:58.765Z (2 months ago)
- Topics: gin, mysql, redis, shorturl
- Language: Go
- Homepage:
- Size: 22.5 KB
- Stars: 21
- Watchers: 1
- Forks: 14
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# short_url
Short link 短链接服务器
### 什么是短链接
就是把普通网址,转换成比较短的网址。比如:https://dwz.cn/XzhYJMkZ### 原理解析
当我们在浏览器里输入 https://dwz.cn/XzhYJMkZ
DNS首先解析获得 https://dwz.cn/ 的 IP 地址
当 DNS 获得 IP 地址以后,会向这个地址发送 HTTP请求,查询短码 XzhYJMkZ
https://dwz.cn/ 服务器会通过短码 XzhYJMkZ 获取对应的长 URL
请求通过 HTTP 301 转到对应的长 URL http://www.baidu.com### 本文采用 自增序列算法 + 用户自定义短码
设置 id 自增,一个 10进制 id 对应一个 62进制的数值,1对1,也就不会出现重复的情况。
这个利用的就是低进制转化为高进制时,字符数会减少的特性。
可使用redis Incr 实现id自增。
### 数据表设计
```base
CREATE TABLE `links` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`url` varchar(200) COLLATE utf8mb4_bin NOT NULL COMMENT '长连接',
`keyword` varchar(50) COLLATE utf8mb4_bin NOT NULL COMMENT '短链接码',
`status` tinyint(1) NOT NULL COMMENT '1系统分配 2用户自定义',
`create_time` bigint(20) NOT NULL,
`update_time` bigint(20) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `links_UN` (`url`),
UNIQUE KEY `links_keyword` (`keyword`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;```
### 服务使用 生成短链接
* post http://127.0.0.1:8099/v1/create_url
* form-data 参数 url 待转换的地址 ,status (1)自动分配 (2)用户自定义 ,keyword 自定义的短码
* 请求值 url:www.google.com status:1 keyword:
* 返回值{
"code": 200,
"data": "http://127.0.0.1:8099/8kBWU",
"msg": "success"
}