国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

短網址原理和實現

sihai / 2296人閱讀

摘要:背景介紹相信很多人手機上都收到過一些營銷短信,短信里面有時候會附帶一些網址,如下圖這些網址往往都是非常短,但是當我們打開之后,如果你仔細觀察,中間會有跳轉,最終瀏覽器地址欄顯示的網址并不是你短信里面看到的網址,這就是短網址原理和應用短網

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 余 8,得16

====> 16%62 余 16,得 0

最終得到的數字是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.安全

短鏈接雖然方便了傳輸和記憶,但是由于鏈接組成的字符個數少,更容易被爆破、猜測攻擊,攻擊者可以輕松遍歷所有字符組成的鏈接!

所以不建議使用短鏈接發送具有私密性的網址,比如說重置密碼鏈接,對一些權限、敏感信息的鏈接要做好二次鑒權!

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/6909.html

相關文章

  • ELSE 技術周刊(2017.11.27期)

    摘要:而且已開源出來,隨著容器技術發展,大文件分發一直是個重要的問題,所以是一件值得研究的技術。實用推薦檢定攻略是近期推出的一項認證,用以認證開發者的移動網頁開發技能。凈化,移除中不必要的文件技術周刊由小組出品,匯聚一周好文章,周刊原文。 業界動態 直擊阿里雙11神秘技術:PB級大規模文件分發系統蜻蜓 文章主要介紹了阿里的PB級大規模文件分發系統蜻蜓, 通過使用P2P技術同時結合智能壓縮、智...

    xushaojieaaa 評論0 收藏0
  • 鏈接原理分析

    摘要:舉個例子,第一個進來的鏈接發號器發號,對應的短鏈接為,第二個進來的鏈接發號器發號,對應的短鏈接為,以此類推。這樣一來會導致一條長鏈接對應多條短鏈接的情況出現,不僅浪費存儲空間,又浪費發號器資源。 1. 什么是短鏈接 顧名思義,短鏈接即是長度較短的網址。通過短鏈接技術,我們可以將長度較長的鏈接壓縮成較短的鏈接。并通過跳轉的方式,將用戶請求由短鏈接重定向到長鏈接上去。短鏈接主要用在諸如微博...

    SexySix 評論0 收藏0
  • 前端有用的網址介紹

    摘要:圖片壓縮網址介紹是一款圖片壓縮工具,壓縮率能達到以上,圖片在壓縮之前和之后幾乎看不出差別。在設計師人群中比較流行,現在介紹給廣大的程序員。 1.圖片壓縮網址:https://tinypng.com/ 介紹: Tinypng 是一款 PNG 圖片壓縮工具,壓縮率能達到 50% 以上,圖片在壓縮之前和之后幾乎看不出差別。Tinypng 在設計師人群中比較流行,現在介紹給廣大的程序員。 據...

    legendmohe 評論0 收藏0

發表評論

0條評論

sihai

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<