短链接核心是ID转码与映射存储:用自增ID经Base62编码生成短码(如123456789→"qQvKx"),Redis存储“短码→原URL”及反向索引,访问时查Redis重定向,辅以校验、限流和TTL过期。

短链接核心逻辑:ID转码与映射存储
短链接本质是把长URL对应到一个简短、唯一的字符串(如 abc123),用户访问该字符串时重定向到原始地址。Golang实现的关键在于:用自增ID或哈希生成短码,再通过键值对存储“短码 → 原URL”关系。推荐用自增ID+Base62编码(0-9a-zA-Z共62字符),避免重复、可预测性低、长度可控。
生成短链接:从URL到短码
接收长URL后,先查数据库/缓存是否已存在;若无,则分配新ID(如用Redis INCR或数据库自增主键),再将ID转为Base62字符串作为短码。例如ID=123456789 → "qQvKx"。注意需校验URL格式(用net/url.Parse),并做去重和长度限制(如最长2048字符)。
- 用
github.com/mrjones/oauth/go/base62或手写Base62编码函数 - 生成前查Redis:
GET url:short:abc123,命中则直接返回 - 未命中则
INCR short:id获取新ID,编码后写入:SET url:short:qQvKx https://example.com/...和SET url:long:https://... qQvKx(反向索引,便于查重)
解析短链接:重定向到原地址
HTTP路由匹配/qQvKx路径,提取短码,查询Redis中url:short:qQvKx的值。若存在,返回302 Found响应,Header设Location: 原URL;若不存在,返回404 Not Found。注意设置Cache-Control: no-cache防止CDN缓存错误跳转。
- 用
http.Redirect(w, r, target, http.StatusFound)完成跳转 - 短码校验:只允许Base62字符,拒绝空、过长(如>12位)、含非法字符的请求
- 可加简单访问统计:每次解析成功后执行
INCR url:stats:qQvKx
基础服务结构与部署建议
用net/http搭轻量API,提供POST /api/v1/shorten(传JSON { "url": "..." })和GET /:code(跳转)。数据层优先选Redis(高性能、支持TTL自动过期),开发阶段可用Map+sync.RWMutex模拟。上线前务必加中间件:限流(如每IP每分钟10次)、防恶意批量生成、HTTPS强制跳转。
立即学习“go语言免费学习笔记(深入)”;
- 短码默认有效期:Redis中设
EXPIRE url:short:qQvKx 365d - 用
gorilla/mux或chi管理路由,清晰分离API与跳转逻辑 - 容器化部署时,将Redis地址通过环境变量注入,避免硬编码










