Golang 生成短链接服务
howie_矜暮 · · 1935 次点击 · · 开始浏览什么是短链接
就是把普通网址,转换成比较短的网址。比如: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自增。
数据表设计
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"
}
完整演示代码 点击这里
联系 QQ: 3355168235
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
什么是短链接
就是把普通网址,转换成比较短的网址。比如: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自增。
数据表设计
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"
}