国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - PHP教程 - php 短鏈接算法收集與分析

php 短鏈接算法收集與分析

2019-12-20 16:26PHP教程網(wǎng) PHP教程

php 短鏈接算法收集與分析,需要的朋友可以參考下。

短鏈接就不說了,大家已經(jīng)都清楚了,如下所示就是短鏈接: 
新浪微博 http://t.cn/SVpONM 
騰訊微博 http://url.cn/302yor 
Yun.io http://d.yun.io/PNri2v 
短鏈接的好處:1、內(nèi)容需要;2、用戶友好;3、便于管理。 
如何實(shí)現(xiàn)呢,大概有三個(gè)步驟: 
1、定義一個(gè)URL映射算法,可以將長的URL映射成短字符串; 
2、使用一個(gè)存儲(chǔ)(數(shù)據(jù)庫?NoSQL?)來存儲(chǔ)完成的映射; 
3、實(shí)現(xiàn)自己的URL映射算法; 
一般來說,第三步是我們比較頭疼的,如何將一個(gè)長的URL字符串,映射成一個(gè)較短的字符串呢。我總結(jié)了三種辦法: 
普通實(shí)現(xiàn) 
我想以前大家學(xué)習(xí)過十進(jìn)制和二進(jìn)制的互相轉(zhuǎn)換,或者十進(jìn)制和十六進(jìn)制的互相轉(zhuǎn)換,那么為了更短,我們可以使用62進(jìn)制,對(duì)于一個(gè)數(shù)字ID進(jìn)行轉(zhuǎn)碼,轉(zhuǎn)換成一個(gè)短字符串。 
這種做法的缺點(diǎn)是沒有辦法保證所有鏈接都是固定的位數(shù)的長度,而且在高并發(fā)的情況下,如何保證能夠快速分發(fā)是個(gè)問題。 
具體實(shí)現(xiàn)方法: 

復(fù)制代碼代碼如下:


/** 
* 利用62進(jìn)制對(duì)數(shù)字ID進(jìn)行短鏈接編碼,缺點(diǎn)不能保證每個(gè)短鏈接是固定長度 

* @author wanshiqiang<wangshiqiang@360.cn> 
* @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; 

/** 
* 對(duì)62進(jìn)制編碼的短鏈接進(jìn)行解碼 

* @author wangshiqiang<wangshiqiang@360.cn> 
* @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; 


文藝實(shí)現(xiàn) 
算法描述:使用6個(gè)字符來表示短鏈接,我們使用ASCII字符中的'a'-'z','0'-'5',共計(jì)32個(gè)字符做為集合。每個(gè)字符有32種狀態(tài),六個(gè)字符就可以表示32^6(1073741824),那么如何得到這六個(gè)字符,描述如下: 
對(duì)傳入的長URL進(jìn)行Md5,得到一個(gè)32位的字符串,這個(gè)字符串變化很多,是16的32次方,基本上可以保證唯一性。將這32位分成四份,每一份8個(gè)字符,這時(shí)機(jī)率變成了16的8次方,是4294967296,這個(gè)數(shù)字碰撞的機(jī)率也比較小啦,關(guān)鍵是后面的一次處理。我們將這個(gè)8位的字符認(rèn)為是16進(jìn)制整數(shù),也就是1*('0x'.$val),然后取0-30位,每5個(gè)一組,算出他的整數(shù)值,然后映射到我們準(zhǔn)備的32個(gè)字符中,最后就能夠得到一個(gè)6位的短鏈接地址。 
PHP實(shí)現(xiàn)如下: 

復(fù)制代碼代碼如下:


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; 


二逼實(shí)現(xiàn) 
下面這個(gè)函數(shù)使用了純隨機(jī)的方式來生成一個(gè)短鏈接,雖然我們可以通過查詢操作來確保不重復(fù)使用短鏈接,可是... 這樣真的靠譜嗎~~ 

復(fù)制代碼代碼如下:


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; 

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品久久久久久久久久久久 | 国产精品1区2区3区 久久免费一区 | 精品www| 亚洲精品一区中文字幕乱码 | 国产一区二区视频在线 | 在线观看av网站永久 | 日韩精品在线一区 | 国产视频一区在线 | 一级黄色片网站 | 精品亚洲一区二区三区四区五区 | 天天爽夜夜爽夜夜爽精品视频 | 国产福利视频在线 | 午夜影院免费观看视频 | 一级片欧美| 96自拍视频| 涩涩视频在线免费看 | av电影免费在线观看 | 亚洲精品久久久久久动漫 | 亚洲男人第一天堂 | 欧美三级网站 | 在线a视频 | 免费一级毛片免费播放 | 国产在线中文字幕 | 91久久综合亚洲鲁鲁五月天 | 一区二区三区在线看 | 一区二区三区欧美 | 国产精品视频一 | 国产视频在线播放 | 欧美一区二区三区在线观看 | 国产精品三级视频 | 日韩在线一区二区三区 | 爱操av| 亚洲国产成人av好男人在线观看 | 一级欧美在线 | 免费成人高清 | 欧美成人免费网站 | 欧美一区二区在线视频 | 亚洲国产一区二区a毛片 | 欧美中文一区二区三区 | 亚洲国产一区二区三区四区 | 黑人精品欧美一区二区蜜桃 |