当前位置:首页 > 短网址资讯

关于短网址算法的讨论和分析

www.ft12.com9年前 (2017-06-12)短网址资讯1349

今天小编无意中在互联网上看到了关于短网址一些算法,非常新奇,和已有的算法有很大的区别:

  1)将长网址md5生成32位签名串,分为4段, 每段8个字节;
  2)对这四段循环处理, 取8个字节, 将他当作16进制串与0x3fffffff(30位1)与操作, 即超越30位的忽略处理;
  3)这30位分成6段, 每5位的数字作为字母表的索引获得特定字符, 顺次进行获得6位字符串;
  4)总的md5串可以获得4个6位串; 取里边的恣意一个就可作为这个长url的短url地址;

完成的版别也许多 ,可是我不明白为何要这么完成,为何要超过30位要疏忽,为啥要生成四个串? 假如生计四个串的话,直接把md5分成4段然后做base62转换不可么?

网上的这些文章都是互相抄来抄去的,这篇文章我看了不下10次了, 这种办法乃至还不如crc32生成一个数字,然后经过62进制变换生成短字符串。

生成短途径一般有2种办法,
1.彻底根据紧缩算法完成,这么的优点是不必数据库,直接紧缩解压即可,可是形似不好完成。
2.根据数据库存储完成。

你列举的即是第二种,这种办法本来生成的字符串根本就无需这么麻烦的生成方法,咱们只需要3个字段即可, 仅有ID,url,md5

咱们只需要知道仅有ID就能够知道这个原地址是什么,咱们刺进的时分,先判别md5存在不,存在就直接回来仅有ID,不存在就刺进,然后回来仅有ID。

仅有ID的生成,假如数据量不大,能够选用mysql的自增,可是一般这种情况下是不会选用mysql的, 所以能够选用时刻戳(看情况是不是按毫秒)+随机码。然后把这个数字变换成62进制即可,缺乏位的能够在前面补0.

首要短网址生成是由于在微博等短文本使用中,长的地址占用空间太大,所以需求短网址服务商将长网址和短链接进行映射,楼主说的base62 即是转换为62进制的数字。62是[a-zA-Z0-9]的数量。
楼主说的位和字节感受概念有紊乱,我了解的是这么的
md5 -> 长度为32的16进制数,比如 a32f232a0ba32f232a0ba32f232a0b11, 然后把这个[1-8][9-16][17-24][25-32],分成了4段,每段有8位16进制的数,一个16进制相当于4位的二进制[1111] = 15 = F, 所以每段相当于32位的二进制,然后取了后30位,后30位平分为6段,每段长度为5bit,相当于有32个数,所以那个映射表估量是[a-z0-5],当然也能够均匀分为5段,每段长度为6bit,这么就有64个,能够[a-zA-Z0-9] 再加两个其它字符(所以这时应当了解为啥要每段5bit了)。
之前不是分为了4段吗, 所以最终长度即是4了。

直接md5 分四段 在base62也能够啊, 就看你映射函数怎样写了,怎么从 每段的 2^32个数 映射到 62个中的一个


扫描二维码推送至手机访问。

版权声明:本文由短链接发布,如需转载请注明出处。

本文链接:https://www.ft12.com/article_196.html

分享给朋友:

相关文章

干货:实战告诉大家如何脚踏实地赚钱

干货:实战告诉大家如何脚踏实地赚钱

每一个混站长圈的朋友,几乎都听说过卢松松博客。我入行较晚,是2012年来到外地读大学,才开始自己摸索着进入站长圈,然后结识松哥博客的。最早,在松哥博客上学习各种建站和优化技术、运营技巧。踏踏实实专研了两年技术以后,开始做自己的个人工作室,然…

高并发秒杀系统架构设计 · 抢购、微信红包、短网址、一元夺宝

高并发秒杀系统架构设计 · 抢购、微信红包、短网址、一元夺宝

秒杀业务与难点秒杀业务在各业务中已然非常流行,这里我将互联网行业中的秒杀定义为:在非常短的时间内,将一件商品分成多份进行购买的行为。微信抢红包、短网址、一元夺宝、双11大促抢购等业务本质上都可视作秒杀业务。而最近大热的抢红包的难度在于这是和…

阿里为什么不收购百度?

阿里为什么不收购百度?

本文来自一个网友的问题汇总,对于阿里为什么不收购百度,网友回复众说纷纭,甚至有的网友反驳提出此问题者有点略显不专业,不管怎么样。让我们来看看大家是怎么看待这件事的!下面这位对系统的分析了阿里跟百度的关系,比较专业值得一看:别说阿里,就算是腾…

全球纯电动车制造商出货量排名:特斯拉仅第二

全球纯电动车制造商出货量排名:特斯拉仅第二

提到电动汽车,我们往往首先想到的是特斯拉,然而根据一份最新调查数据显示,特斯拉并非全球最大的电动汽车制造商。据JATO数据提供商最新公开的纯电动车制造商排名显示,目前雷诺-日产是全球最大的纯电动车制造商,特斯拉排在第二位,其它前十名厂商分别…

如何才能让网络爬虫抓取短链接?

网络爬虫(又被称爲网页蜘蛛,网络机器人),是一种依照一定的规则、自动的抓取万维网信息的顺序或许脚本。通常它爲搜索引擎从万维网上下载网页,是搜索引擎的重要组成局部。抓取战略链接的抓取战略可以分爲深度优先、广度优先和最佳优先三种。1、深度化先捜…

“色流”产业十年风云录:40万大军,吸食百亿利润

“色流”产业十年风云录:40万大军,吸食百亿利润

色流群体如蚂蚁一般,跟随着流量蜜罐迁移,经历多个时代的轮回变迁,并分食百亿级别市场……标题:“色流”产业十年风云录:40万大军,吸食百亿利润来源:一本财经,已授权『互联网的一些事』,转载请联系作者。在“流量为王”的时代,流量在某种意义上,就…

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。