php实现的短网址算法分享

前端之家收集整理的这篇文章主要介绍了php实现的短网址算法分享前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

每个网址用6个字符代替,(6^32) 最多可以拥有1,073,741,824个短网址。 当然,你还可以记录更详细的信息,如访问记录,创建时间等。 如果真不够用了,还可以删掉很久不用的。

代码如下:
$hex = md5($input);
$hexLen = strlen($hex);
$subHexLen = $hexLen / 8;
$output = array();

for ($i = 0; $i < $subHexLen; $i++) {
$subHex = substr ($hex,$i 8,8);
$int = 0x3FFFFFFF & (1
('0x'.$subHex));
$out = '';

for ($j = 0; $j < 6; $j++) {
$val = 0x0000001F & $int;
$out .= $base32[$val];
$int = $int >> 5;
}

$output[] = $out;
}

return $output;
}

测试代码

代码如下:
echo "Input : $input\n";
echo "Output : {$output[0]}\n";
echo " {$output[1]}\n";
echo " {$output[2]}\n";
echo " {$output[3]}\n";
echo "\n";

$input = '//www.jb51.cc/2';
$output = shorturl($input);

echo "Input : $input\n";
echo "Output : {$output[0]}\n";
echo " {$output[1]}\n";
echo " {$output[2]}\n";
echo " {$output[3]}\n";
echo "\n";

输出

代码如下:
Input : //www.jb51.cc/2
Output : tm5kxb
ceoj2s
yw3dvl
nrmrxl

猜你在找的PHP相关文章