短链接系统如何设计

December 09, 2023
测试
测试
测试
测试
1 分钟阅读

shigen坚持日更的博客写手,擅长Java、python、vue、shell等编程语言和各种应用程序、脚本的开发。坚持记录和分享从业两年以来的技术积累和思考,不断沉淀和成长。

今天给大家带来的文章是:《短链接系统如何设计》。在开始之前,先让我们熟悉一下什么是长链接:

常见的长链接
常见的长链接

shigen相信:这类系统大家都有遇到过,一看到就很头疼。要么是域名特别长,要么是带的参数特别多。那这样的自然就有很多的问题:

  1. 存在粘贴的时候粘贴不完全导致目标资源无法访问
  2. 太长了,导致我们使用三方服务,如:阿里云短信服务导致了额外的费用
  3. 部分业务系统表单提交url的时候有字符的长度限制

…….

以上就是我觉得长链接不太合适的地方,那如何的缩短或者简化一下长链接呢?这里的短链接系统的需求就应运而生。短链接系统设计代码全部放在了这里,需要的伙伴可自行查看。

我们先来分析一下短地址,这是shigen找到的在线的短地址生成的工具箱:

在线的短地址生成
在线的短地址生成

可以看到我给了一个很长的地址,转换之后,我的地址就很短了。是不是很神奇,更神奇的是我直接拿我的短地址就可以访问到我的长地址。好了,效果和功能都摆在了这里,具体的怎么实现呢?来和shigen一起进行系统设计。


在设计之前我们需要明确的问题和要点有:

🫢🫢🫢短链接的作用:

  1. 使链接更加的短
  2. 安全性的需求

🤔🤔短链接的算法

  1. 数据库自增的ID,ID的字段类型设计成int64,可以保存11位的数值
  2. MD5算法,生成一段字符串

🫤🫤其它考虑的点

  1. 短链接的缓存方案,使用懒加载;是否需要短链接的有效期
  2. 静态资源的访问,是否仍然可以反向代理

带着这些问题,shigen开始了系统的设计。

✊✊✊✊开始干活了!

短链接转长链接的工具类

这里主要是对长链接进行md5hash算法,得到一个长字符串,然后进一步采用算法,选取了其中的6个字符,作为长链接映射的code。

短链接实体定义

这个没啥好说的,和数据表的字段是对应的,关键的就是originUrlshortCode的映射。

短链接逻辑处理

这里的代码稍微多一点,主要是做了数据存储和数据查询的数据缓存。

一样,这样只适合单机模式,多实例模式还需要考虑数据库和缓存数据一致性问题。

对外的接口

这样,上边的代码写的差不多了,现在就需要编写接口进行测试了。

效果测试

就是两个接口,一个保存,一个查询的接口,我们来测试一下效果:

保存链接
保存链接

保存完毕之后,直接跳转到了新页面。页面跳转太快,效果就不好展示了!

一样,我用生成的code也可以访问:

用code访问页面
用code访问页面

在markdown中使用短链接引用静态资源:

在markdown中引用静态资源
在markdown中引用静态资源

检查一下DB:

  • mysql
mysql中的数据
mysql中的数据
  • redis
redis中的数据
redis中的数据

除了redis的数据序列化问题,可以看到我的效果是成功的实现了。


以上就是今天分享的全部内容了,觉得不错的话,记得点赞 在看 关注支持一下哈,您的鼓励和支持将是shigen坚持日更的动力。

与**shigen**一起,每天不一样!

继续阅读

更多来自我们博客的帖子

如何安装 BuddyPress
由 测试 December 17, 2023
经过差不多一年的开发,BuddyPress 这个基于 WordPress Mu 的 SNS 插件正式版终于发布了。BuddyPress...
阅读更多
Filter如何工作
由 测试 December 17, 2023
在 web.xml...
阅读更多
如何理解CGAffineTransform
由 测试 December 17, 2023
CGAffineTransform A structure for holding an affine transformation matrix. ...
阅读更多