天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

php 短鏈接算法收集與分析

短鏈接就不說了,大家已經都清楚了,如下所示就是短鏈接:
新浪微博 http://t.cn/SVpONM
騰訊微博 http://url.cn/302yor
Yun.io http://d.yun.io/PNri2v
短鏈接的好處:1、內容需要;2、用戶友好;3、便于管理。
如何實現呢,大概有三個步驟:
1、定義一個URL映射算法,可以將長的URL映射成短字符串;
2、使用一個存儲(數據庫?NoSQL?)來存儲完成的映射;
3、實現自己的URL映射算法;
一般來說,第三步是我們比較頭疼的,如何將一個長的URL字符串,映射成一個較短的字符串呢。我總結了三種辦法:
普通實現
我想以前大家學習過十進制和二進制的互相轉換,或者十進制和十六進制的互相轉換,那么為了更短,我們可以使用62進制,對于一個數字ID進行轉碼,轉換成一個短字符串。
這種做法的缺點是沒有辦法保證所有鏈接都是固定的位數的長度,而且在高并發的情況下,如何保證能夠快速分發是個問題。
具體實現方法:
復制代碼 代碼如下:
/**
* 利用62進制對數字ID進行短鏈接編碼,缺點不能保證每個短鏈接是固定長度
*
* @author wanshiqiang<[email protected]>
* @param integer $integer
* @param string $base
*/
private function getShortenedURLFromID ($integer, $base = ALLOWED_CHARS)
{
$length = strlen($base);
while($integer > $length - 1)
{
$out = $base[fmod($integer, $length)] . $out;
$integer = floor( $integer / $length );
}
return $base[$integer] . $out;
}
/**
* 對62進制編碼的短鏈接進行解碼
*
* @author wangshiqiang<[email protected]>
* @param string $string
* @param string $base
*/
private function getIDFromShortenedURL ($string, $base = ALLOWED_CHARS)
{
$length = strlen($base);
$size = strlen($string) - 1;
$string = str_split($string);
$out = strpos($base, array_pop($string));
foreach($string as $i => $char)
{
$out += strpos($base, $char) * pow($length, $size - $i);
}
return $out;
}

文藝實現
算法描述:使用6個字符來表示短鏈接,我們使用ASCII字符中的'a'-'z','0'-'5',共計32個字符做為集合。每個字符有32種狀態,六個字符就可以表示32^6(1073741824),那么如何得到這六個字符,描述如下:
對傳入的長URL進行Md5,得到一個32位的字符串,這個字符串變化很多,是16的32次方,基本上可以保證唯一性。將這32位分成四份,每一份8個字符,這時機率變成了16的8次方,是4294967296,這個數字碰撞的機率也比較小啦,關鍵是后面的一次處理。我們將這個8位的字符認為是16進制整數,也就是1*('0x'.$val),然后取0-30位,每5個一組,算出他的整數值,然后映射到我們準備的32個字符中,最后就能夠得到一個6位的短鏈接地址。
php實現如下:
復制代碼 代碼如下:
function shorten( $long_url )
{
$base32 = "abcdefghijklmnopqrstuvwxyz012345";
$hex = md5( $long_url );
$hexLen = strlen( $hex );
$subHexLen = $hexLen / 8;
$output = array();
for( $i = 0; $i < $subHexLen; $i++ )
{
$subHex = substr( $hex, $i * 8, 8 );
$subHex = 0x3FFFFFFF & ( 1 * ('0x' . $subHex ) );
    $out = '';
for( $j = 0; $j < 6; $j++ )
{
$val = 0x0000001F & $int;
$out .= $base32[$val];
$int = $int >> 5;
}
$output[] = $out;
}
return $output;
}

二逼實現
下面這個函數使用了純隨機的方式來生成一個短鏈接,雖然我們可以通過查詢操作來確保不重復使用短鏈接,可是... 這樣真的靠譜嗎~~
復制代碼 代碼如下:
function random($length, $pool = '') {
$random = '';
if (empty($pool)) { $pool = 'abcdefghkmnpqrstuvwxyz'; $pool .=
'23456789'; }
srand ((double)microtime()*1000000);
for($i = 0; $i < $length; $i++) { $random .=
substr($pool,(rand()%(strlen ($pool))), 1); }
return $random;
}

Technorati 標簽: 短鏈接,Short Url,映射,哈希

參考資料:

1、微博短地址原理解析

2、微博短域名原理及作用

3、Yours.org

4、Free php URL Shorten script that kicks ass

5、php Short Url Algorithm Implementation

6、Implement your own short URL

7、短網址算法初步匯總

8、Short Url 實現方式

php技術php 短鏈接算法收集與分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美高清一区二区三 | 中国字字幕在线播放2019 | 激情床戏揉胸吃胸视频 | 嫩草电影网嫩草影院 | 亚洲午夜久久久久久久久电影网 | 天天摸夜添狠狠添高 | 羞羞漫画在线播放 | 国产午夜精品福利久久 | 国产精一品亚洲二区在线播放 | 色婷婷AV国产精品欧美毛片 | 99热视频这里只有久久精品 | 亚州综人网 | 99久久精品国产一区二区三区 | 色欲天天天综合网免费 | 国产精品JIZZ视频免费 | 日本福利片午夜免费观着 | 国产亚洲人成网站在线观看播放 | 亚洲精品自在在线观看 | 久久 这里只精品 免费 | 国产亚洲视频在线播放香蕉 | 欧美互交人妖247 | 麻豆第一区MV免费观看网站 | www免费看.男人的天堂 | 蜜芽国产在线精品欧美 | 四虎永久在线精品免费A | 亚洲伊人久久综合影院2021 | 亚洲精品中文字幕无码A片蜜桃 | 在线观看成年人免费视频 | 97视频免费在线观看 | 日本黄色官网 | 国产精品97久久久久久AV色戒 | 香蕉水蜜桃牛奶涩涩 | 欧美亚洲日韩国码在线观看 | 日韩插啊免费视频在线观看 | 国产精品99久久免费黑人人妻 | 全黄h全肉细节文在线观看 全黄H全肉细节文短篇 | 东京热 百度影音 | 日韩精品人成在线播放 | 深夜释放自己在线观看 | 女配穿书病娇被强啪h | 亚洲午夜久久久久中文字幕 |