欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php 短鏈接算法收集與分析

 更新時間:2011年12月30日 00:01:44   投稿:mdxy-dxy  
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)呢,大概有三個步驟:
1、定義一個URL映射算法,可以將長的URL映射成短字符串;
2、使用一個存儲(數(shù)據(jù)庫?NoSQL?)來存儲完成的映射;
3、實(shí)現(xiàn)自己的URL映射算法;
一般來說,第三步是我們比較頭疼的,如何將一個長的URL字符串,映射成一個較短的字符串呢。我總結(jié)了三種辦法:
普通實(shí)現(xiàn)
我想以前大家學(xué)習(xí)過十進(jìn)制和二進(jìn)制的互相轉(zhuǎn)換,或者十進(jìn)制和十六進(jìn)制的互相轉(zhuǎn)換,那么為了更短,我們可以使用62進(jìn)制,對于一個數(shù)字ID進(jìn)行轉(zhuǎn)碼,轉(zhuǎn)換成一個短字符串。
這種做法的缺點(diǎn)是沒有辦法保證所有鏈接都是固定的位數(shù)的長度,而且在高并發(fā)的情況下,如何保證能夠快速分發(fā)是個問題。
具體實(shí)現(xiàn)方法:

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

/**
* 利用62進(jìn)制對數(shù)字ID進(jìn)行短鏈接編碼,缺點(diǎn)不能保證每個短鏈接是固定長度
*
* @author wanshiqiang<wangshiqiang@#>
* @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進(jìn)制編碼的短鏈接進(jìn)行解碼
*
* @author wangshiqiang<wangshiqiang@#>
* @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個字符來表示短鏈接,我們使用ASCII字符中的'a'-'z','0'-'5',共計32個字符做為集合。每個字符有32種狀態(tài),六個字符就可以表示32^6(1073741824),那么如何得到這六個字符,描述如下:
對傳入的長URL進(jìn)行Md5,得到一個32位的字符串,這個字符串變化很多,是16的32次方,基本上可以保證唯一性。將這32位分成四份,每一份8個字符,這時機(jī)率變成了16的8次方,是4294967296,這個數(shù)字碰撞的機(jī)率也比較小啦,關(guān)鍵是后面的一次處理。我們將這個8位的字符認(rèn)為是16進(jìn)制整數(shù),也就是1*('0x'.$val),然后取0-30位,每5個一組,算出他的整數(shù)值,然后映射到我們準(zhǔn)備的32個字符中,最后就能夠得到一個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)
下面這個函數(shù)使用了純隨機(jī)的方式來生成一個短鏈接,雖然我們可以通過查詢操作來確保不重復(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;
}

Technorati 標(biāo)簽: ,,,

參考資料:

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、短網(wǎng)址算法初步匯總

8、Short Url 實(shí)現(xiàn)方式

相關(guān)文章

  • PHP積分兌換接口實(shí)例

    PHP積分兌換接口實(shí)例

    這篇文章主要介紹了PHP積分兌換接口,實(shí)例分析了積分兌換接口的邏輯處理與數(shù)據(jù)庫操作技巧,需要的朋友可以參考下
    2015-02-02
  • php寫app用的框架整理

    php寫app用的框架整理

    在本篇文章里小編給大家整理的是關(guān)于php寫app用的框架的相關(guān)知識點(diǎn),有需要的朋友們學(xué)習(xí)下。
    2019-09-09
  • PHP spl_autoload_register實(shí)現(xiàn)自動加載研究

    PHP spl_autoload_register實(shí)現(xiàn)自動加載研究

    spl_autoload_register()函數(shù)應(yīng)該是主流框架使用最多的也是非常核心的函數(shù)之一,可實(shí)現(xiàn)自動注冊函數(shù)和類,實(shí)現(xiàn)類似__autoload() 函數(shù)功能,簡化了類的調(diào)用與加載,提高了工作的效率
    2011-12-12
  • php通過淘寶API查詢IP地址歸屬等信息

    php通過淘寶API查詢IP地址歸屬等信息

    這篇文章主要介紹了php通過淘寶API查詢IP地址歸屬等信息的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • PHP gbk環(huán)境下json_dencode傳送來的漢字

    PHP gbk環(huán)境下json_dencode傳送來的漢字

    在做一個小項目的時候用得gbk,發(fā)現(xiàn)json_encode傳過來的漢子不對。搜索出結(jié)果。。留下印子不忘記。。歡迎指正
    2012-11-11
  • PHP針對redis常用操作實(shí)例詳解

    PHP針對redis常用操作實(shí)例詳解

    這篇文章主要介紹了PHP針對redis常用操作,結(jié)合實(shí)例形式詳細(xì)分析了PHP針對Redis連接、增刪改查及各種常用運(yùn)算操作技巧,需要的朋友可以參考下
    2019-08-08
  • php+iframe 實(shí)現(xiàn)上傳文件功能示例

    php+iframe 實(shí)現(xiàn)上傳文件功能示例

    這篇文章主要介紹了php+iframe 實(shí)現(xiàn)上傳文件功能,結(jié)合實(shí)例形式分析了PHP通過動態(tài)的創(chuàng)建iframe實(shí)現(xiàn)上傳文件的具體步驟、實(shí)現(xiàn)方法與操作注意事項,需要的朋友可以參考下
    2020-03-03
  • PHP define函數(shù)的使用說明

    PHP define函數(shù)的使用說明

    PHP預(yù)先定義了幾個常量,并提供了一種機(jī)制在運(yùn)行時自己定義。常量和變量基本上是一樣的,不同的是:常量必須用DEFINE函數(shù)定義,常量一旦定義好,就不能被重新定義了。
    2008-08-08
  • str_replace只替換一次字符串的方法

    str_replace只替換一次字符串的方法

    我們都知道,在PHP里Strtr,strreplace等函數(shù)都可以用來替換,不過他們每次替換的時候都是全部替換,但是如果你想只替換一個或兩個怎么辦呢?看下邊的解決方法
    2013-04-04
  • PHP cookie,session的使用與用戶自動登錄功能實(shí)現(xiàn)方法分析

    PHP cookie,session的使用與用戶自動登錄功能實(shí)現(xiàn)方法分析

    這篇文章主要介紹了PHP cookie,session的使用與用戶自動登錄功能實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了php使用cookie與session進(jìn)行數(shù)據(jù)存取以及實(shí)現(xiàn)自動登陸功能的相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06

最新評論