您好,登錄后才能下訂單哦!
這篇文章主要介紹PHP實現短網址的方法,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
1.背景介紹
相信很多人手機上都收到過一些營銷短信,短信里面有時候會附帶一些網址,如下圖
這些網址往往都是非常短,但是當我們打開之后,如果你仔細觀察,中間會有跳轉,最終瀏覽器地址欄顯示的網址并不是你短信里面看到的網址,這就是短網址!
2.原理和應用
短網址一般是采用一個非常短域名下,路徑參數一般只有3-6個字符組成,非常簡潔!
使用短網址的前提是先生成短網址,主要是采用某種算法讓一段短的字符對應一個長的字符,比如說從常用的0-9、a-z、A-Z共62個字符中選擇6個字符,那意味著有62的6次方種組合,大概有568億不重復的短網址可用!
服務器通過路徑參數查詢到真實的長網址,然后使用301/302跳轉到真實的網址即可!
關于跳轉,301 是永久重定向,302 是臨時重定向。短地址一經生成就不會變化,所以用 301 是符合 http 語義的,瀏覽器會記錄跳轉地址,同時對服務器壓力也會有一定減少。但是如果使用了 301,我們就無法統計到短地址被點擊的次數了,如果對數據統計有要求的話,使用302跳轉可能比較好一些!
短網址的主要好處是方便傳輸記憶,特別是在短信里面使用的時候,短信對內容字數有限制,還有比如說微博分享也使用了短網址!
3.市面現有案例
目前市面上有很多免費的短鏈接服務,功能基本上都一樣,也沒有什么限制!
(1)百度的短鏈接(dwz.cn/),百度不僅僅提供了網頁入口,也提供了接口和開發文檔,簡單易用!
(2)新浪的短鏈接(sina.lt/),目前僅提供網頁入口,未發現接口服務!
(3)淘寶的短鏈接(tb.am/),目前僅提供網頁入口,未發現接口服務!
市面還有很多其它的小的公司提供短鏈接服務,有些是部分免費,有些短鏈接是有效期的,這里不一一介紹!
4.常用算法
網上比較流行的算法有進制算法、摘要(Hash)算法、隨機數算法,下面簡單介紹一下:
一.進制算法
這個算法網上也有叫作自增序列算法,特點就是永不重復,設置 id 自增,一個 10進制 id 對應一個62進制的數值,1對1,也就不會出現重復的情況,這個利用的就是低進制轉化為高進制時,字符數會減少的特性。
計算機中常見的進制有2進制,8進制,10進制,16進制,進制越大,能夠表示的數越大,占用的字數也越少。下面舉個例:
10進制的1000,在8進制里面是1750,在16進制里面就是3E8,那在62進制里面呢?有人說,計算機里面沒有62進制。。。雖然沒有,但是我們可以造一個,進制的轉換算法是固定的,最常見的就是“除基取余法”!
我們假設62進制的字符序列為 0-9a-zA-Z,順序可以打亂,但是應該固定下來,是一個從0角標開始的到61的數組,我們暫且稱之為字母表!
====> 1000/62 = 16,余8
====> 16/62 = 0,余16
余數得到的數字是16、8,然后找到字母表里面角標為16和8的字符拼起來,就是g8,非常短,只有2位數!假如說我們想至少產生6位字符,那么我們可以從一個比較大的數字開始,具體可以看下圖:
1位 62 0 - 61 2位 3844 62 - 3843 3位 約 23萬 3844 - 238327 4位 約 1400萬 238328 - 14776335 5位 約 9.1億 14776336 - 916132831 6位 約 568億 916132832 - 56800235583 復制代碼
二.Hash算法
第一種方式:
簡單的對長鏈接進行加鹽md5,會生成一個32位的字符串,隨機從里面取6個字符,或者簡單粗暴取最后6位,但是md5只包含0-9A-Fa-f,比字母表的里面字符還少,沖突幾率更大!
第二種方式:
1.將長網址 md5 生成 32 位簽名串,分為 4 段, 每段 8 個字節
2.對這四段循環處理, 取 8 個字節, 將他看成 16 進制串與 0x3fffffff(30位1) 與操作, 即超過 30 位的忽略處理
3.這 30 位分成 6 段, 每 5 位的數字作為字母表的索引取得特定字符, 依次進行獲得 6 位字符串
4.總的 md5 串可以獲得 4 個 6 位串,取里面的任意一個就可作為這個長 url 的短 url 地址
生成的方式更加復雜,重復的幾率低,但是依然會出現沖突!
三.隨機數算法
這個更簡單,直接對這個62個字符數組做隨機選擇,選擇其中6個字符當作短鏈接碼,簡單易用,但是難免會出現重復沖突!
四.算法對比
第一種算法只要解決自增id問題就可以避免沖突,自增id可以采用數據庫自增主鍵,每次生成短碼只需一次數據庫操作(insert操作,獲取主鍵id,然后算出短碼即可)
第二種和第三種算法其實都差不多,都是依賴于程序隨機,容易出現沖突,這就需要每次在插入數據庫的時候判重,效率低一些!
5.安全
短鏈接雖然方便了傳輸和記憶,但是由于鏈接組成的字符個數少,更容易被爆破、猜測攻擊,攻擊者可以輕松遍歷所有字符組成的鏈接!
所以不建議使用短鏈接發送具有私密性的網址,比如說重置密碼鏈接,對一些權限、敏感信息的鏈接要做好二次鑒權!
以上是PHP實現短網址的方法的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。