搜索
首页php教程php手册微博短链接算法php版本实现代码

微博短链接算法php版本实现代码

Jun 13, 2016 am 11:58 AM
32位md5php代码实现微博思路版本生成签名算法网址链接

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

复制代码 代码如下:


function shorturl($url='', $prefix='', $suffix='') {
$base = array (
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
'q', 'r', 's', 't', 'u', 'v', 'w', 'x',
'y', 'z', '0', '1', '2', '3', '4', '5');
$hex = md5($prefix.$url.$suffix);
$hexLen = strlen($hex);
$subHexLen = $hexLen / 8;
$output = array();
for ($i = 0; $i $subHex = substr ($hex, $i * 8, 8);
$int = 0x3FFFFFFF & (1 * ('0x'.$subHex));
$out = '';
for ($j = 0; $j $val = 0x0000001F & $int;
$out .= $base[$val];
$int = $int >> 5;
}
$output[] = $out;
}
return $output;
}
$urls = shorturl('http://www.jb51.net/');
var_dump($urls);


结果

复制代码 代码如下:


array(4) {
[0]=>
string(6) "alms1l"
[1]=>
string(6) "2ipmby"
[2]=>
string(6) "avo1hu"
[3]=>
string(6) "fdlban"
}


另外一个版本:

复制代码 代码如下:


function shorturl($url='', $prefix='', $suffix='') {
$base = array(
"a","b","c","d","e","f","g","h",
"i","j","k","l","m","n","o","p",
"q","r","s","t","u","v","w","x",
"y","z","0","1","2","3","4","5",
"6","7","8","9","A","B","C","D",
"E","F","G","H","I","J","K","L",
"M","N","O","P","Q","R","S","T",
"U","V","W","X","Y","Z");
$hex = md5($prefix.$url.$suffix);
$hexLen = strlen($hex);
$subHexLen = $hexLen / 8;
$output = array();
for ($i = 0; $i $subHex = substr ($hex, $i * 8, 8);
$int = 0x3FFFFFFF & (1 * ('0x'.$subHex));
$out = '';
for ($j = 0; $j $val = 0x0000003D & $int;
$out .= $base[$val];
$int = $int >> 5;
}
$output[] = $out;
}
return $output;
}


结果:

复制代码 代码如下:


array(4) {
[0] =>
string(6) "6jmMVj"
[1] =>
string(6) "2EnIby"
[2] =>
string(6) "6vIVfu"
[3] =>
string(6) "B7Fb6n"
}


但是升级版本碰撞率反而更高了,不知道为什么。
测试碰撞的测试代码:

复制代码 代码如下:


$result = array();
$repeats= array();
$loop = 20000;
for($i=0;$i$url = 'http://www.jb51.net/?id='.$i;
$shorta = shorturl($url);
$short = $shorta[0];
if(in_array($short, $result)){
$repeats[] = $short;
}
$result[] = $short;
}
$result = array();
for($i=0;$i$url = 'http://www.jb51.net/?id='.$i;
$shorta = shorturl($url);
$short = $shorta[0];
if(in_array($short, $repeats)){
$result[$short][] = $url;
}
}
var_dump($repeats);
var_dump($result);


结果:

复制代码 代码如下:


数组(8) {
[0] =>;
string(6) "3eQBzq"
[1] =>;
string(6) "uQFnay"
[2] =>;
string(6) "qEZbIv"
[3] =>;
string(6) "fMneYf"
[4] =>;
string(6) "FJj6Fr"
[5] =>;
string(6) "3Eviym"
[6] =>;
string(6) "j2mmuy"
[7] =>;
string(6) "jyQfIv"
}
数组(8) {
'jyQfIv' =>;
数组(2) {
[0] =>;
string(26) "http://www.jb51.net/?id=1640"
[1] =>;
string(27) "http://www.jb51.net/?id=18661"
}
'fMneYf' =>;
数组(2) {
[0] =>;
string(26) "http://www.jb51.net/?id=2072"
[1] =>;
string(26) "http://www.jb51.net/?id=8480"
}
'3eQBzq' =>;
数组(2) {
[0] =>;
string(26) "http://www.jb51.net/?id=4145"
[1] =>;
string(26) "http://www.jb51.net/?id=4273"
}
'j2mmuy' =>;
数组(2) {
[0] =>;
string(26) "http://www.jb51.net/?id=7131"
[1] =>;
string(27) "http://www.jb51.net/?id=17898"
}
'qEZbIv' =>;
数组(2) {
[0] =>;
string(26) "http://www.jb51.net/?id=7320"
[1] =>;
string(26) "http://www.jb51.net/?id=8134"
}
'uQFnay' =>;
数组(2) {
[0] =>;
string(26) "http://www.jb51.net/?id=7347"
[1] =>;
string(26) "http://www.jb51.net/?id=7962"
}
'FJj6Fr' =>;
数组(2) {
[0] =>;
string(26) "http://www.jb51.net/?id=8628"
[1] =>;
string(26) "http://www.jb51.net/?id=9031"
}
'3Eviym' =>;
数组(2) {
[0] =>;
string(27) "http://www.jb51.net/?id=11175"
[1] =>;
string(27) "http://www.jb51.net/?id=14437"
}
}

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具