用PHP實現URL轉換短網址的算法示例


短網址就是把一個長的地址轉換在超級短的網址,然后訪問短網址即可跳轉到長網址了,下面來看用PHP實現URL轉換短網址的算法與例子。

短網址(Short URL) ,顧名思義就是在形式上比較短的網址。在Web 2.0的今天,不得不說,這是一個潮流。目前已經有許多類似服務,借助短網址您可以用簡短的網址替代原來冗長的網址,讓使用者可以更容易的分享鏈接。

算法原理

1)將長網址md5生成32位簽名串,分為4段, 每段8個字節;
2)對這四段循環處理, 取8個字節, 將他看成16進制串與0x3fffffff(30位1)與操作, 即超過30位的忽略處理;
3)這30位分成6段, 每5位的數字作為字母表的索引取得特定字符, 依次進行獲得6位字符串;
4)總的md5串可以獲得4個6位串; 取里面的任意一個就可作為這個長url的短url地址;

下面是用PHP實現短網址轉換的算法,代碼如下:

PHP

 代碼如下 復制代碼

<?php
//短網址生成算法
class ShortUrl {
    
    //字符表
    public static $charset = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
 
    public static function encode($url)
    {
        $key = 'abc'; //加鹽
        $urlhash = md5($key . $url);
        $len = strlen($urlhash);
 
        //將加密后的串分成4段,每段4字節,對每段進行計算,一共可以生成四組短連接
        for ($i = 0; $i < 4; $i++) {
            $urlhash_piece = substr($urlhash, $i * $len / 4, $len / 4);
            
            //將分段的位與0x3fffffff做位與,0x3fffffff表示二進制數的30個1,即30位以后的加密串都歸零
            //此處需要用到hexdec()將16進制字符串轉為10進制數值型,否則運算會不正常
            $hex = hexdec($urlhash_piece) & 0x3fffffff;
 
            //域名根據需求填寫
            $short_url = "http://t.cn/";
            
            //生成6位短網址
            for ($j = 0; $j < 6; $j++) {
                
                //將得到的值與0x0000003d,3d為61,即charset的坐標最大值
                $short_url .= self::$charset[$hex & 0x0000003d];
                
                //循環完以后將hex右移5位
                $hex = $hex >> 5;
            }
 
            $short_url_list[] = $short_url;
        }
 
        return $short_url_list;
    }
}
 
$url = "http://www.111cn.net/";
$short = ShortUrl::encode($url);
print_r($short);
?>

通常我們用四組網址中的第一組即可。

這里需要注意的是,這個算法是不可逆的,因此,通常的做法是將短網址和對應的原網址存入數據庫,當訪問時,從數據庫中取出匹配的原網址,通過301或header進行跳轉。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM