什么是短链接
原理解析
当我们在浏览器里输入 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,
PRIMAR