亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

短網(wǎng)址原理和實(shí)現(xiàn)

sihai / 2388人閱讀

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

1.背景介紹

相信很多人手機(jī)上都收到過(guò)一些營(yíng)銷短信,短信里面有時(shí)候會(huì)附帶一些網(wǎng)址,如下圖

這些網(wǎng)址往往都是非常短,但是當(dāng)我們打開之后,如果你仔細(xì)觀察,中間會(huì)有跳轉(zhuǎn),最終瀏覽器地址欄顯示的網(wǎng)址并不是你短信里面看到的網(wǎng)址,這就是短網(wǎng)址!

2.原理和應(yīng)用

短網(wǎng)址一般是采用一個(gè)非常短域名下,路徑參數(shù)一般只有3-6個(gè)字符組成,非常簡(jiǎn)潔!

使用短網(wǎng)址的前提是先生成短網(wǎng)址,主要是采用某種算法讓一段短的字符對(duì)應(yīng)一個(gè)長(zhǎng)的字符,比如說(shuō)從常用的0-9、a-z、A-Z共62個(gè)字符中選擇6個(gè)字符,那意味著有62的6次方種組合,大概有568億不重復(fù)的短網(wǎng)址可用!

服務(wù)器通過(guò)路徑參數(shù)查詢到真實(shí)的長(zhǎng)網(wǎng)址,然后使用301/302跳轉(zhuǎn)到真實(shí)的網(wǎng)址即可!

關(guān)于跳轉(zhuǎn),301 是永久重定向,302 是臨時(shí)重定向。短地址一經(jīng)生成就不會(huì)變化,所以用 301 是符合 http 語(yǔ)義的,瀏覽器會(huì)記錄跳轉(zhuǎn)地址,同時(shí)對(duì)服務(wù)器壓力也會(huì)有一定減少。但是如果使用了 301,我們就無(wú)法統(tǒng)計(jì)到短地址被點(diǎn)擊的次數(shù)了,如果對(duì)數(shù)據(jù)統(tǒng)計(jì)有要求的話,使用302跳轉(zhuǎn)可能比較好一些!

短網(wǎng)址的主要好處是方便傳輸記憶,特別是在短信里面使用的時(shí)候,短信對(duì)內(nèi)容字?jǐn)?shù)有限制,還有比如說(shuō)微博分享也使用了短網(wǎng)址!

3.市面現(xiàn)有案例

目前市面上有很多免費(fèi)的短鏈接服務(wù),功能基本上都一樣,也沒(méi)有什么限制!

(1)百度的短鏈接(dwz.cn/),百度不僅僅提供了網(wǎng)頁(yè)入口,也提供了接口和開發(fā)文檔,簡(jiǎn)單易用!

(2)新浪的短鏈接(sina.lt/),目前僅提供網(wǎng)頁(yè)入口,未發(fā)現(xiàn)接口服務(wù)!

(3)淘寶的短鏈接(tb.am/),目前僅提供網(wǎng)頁(yè)入口,未發(fā)現(xiàn)接口服務(wù)!

市面還有很多其它的小的公司提供短鏈接服務(wù),有些是部分免費(fèi),有些短鏈接是有效期的,這里不一一介紹!

4.常用算法

網(wǎng)上比較流行的算法有進(jìn)制算法、摘要(Hash)算法、隨機(jī)數(shù)算法,下面簡(jiǎn)單介紹一下:

一.進(jìn)制算法

這個(gè)算法網(wǎng)上也有叫作自增序列算法,特點(diǎn)就是永不重復(fù),設(shè)置 id 自增,一個(gè) 10進(jìn)制 id 對(duì)應(yīng)一個(gè)62進(jìn)制的數(shù)值,1對(duì)1,也就不會(huì)出現(xiàn)重復(fù)的情況,這個(gè)利用的就是低進(jìn)制轉(zhuǎn)化為高進(jìn)制時(shí),字符數(shù)會(huì)減少的特性。

計(jì)算機(jī)中常見的進(jìn)制有2進(jìn)制,8進(jìn)制,10進(jìn)制,16進(jìn)制,進(jìn)制越大,能夠表示的數(shù)越大,占用的字?jǐn)?shù)也越少。下面舉個(gè)例:

10進(jìn)制的1000,在8進(jìn)制里面是1750,在16進(jìn)制里面就是3E8,那在62進(jìn)制里面呢?有人說(shuō),計(jì)算機(jī)里面沒(méi)有62進(jìn)制。。。雖然沒(méi)有,但是我們可以造一個(gè),進(jìn)制的轉(zhuǎn)換算法是固定的,最常見的就是“除基取余法”!

我們假設(shè)62進(jìn)制的字符序列為 0-9a-zA-Z,順序可以打亂,但是應(yīng)該固定下來(lái),是一個(gè)從0角標(biāo)開始的到61的數(shù)組,我們暫且稱之為字母表!

====> 1000%62 余 8,得16

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

最終得到的數(shù)字是16、8,然后找到字母表里面角標(biāo)為16和8的字符拼起來(lái),就是g8,非常短,只有2位數(shù)!假如說(shuō)我們想至少產(chǎn)生6位字符,那么我們可以從一個(gè)比較大的數(shù)字開始,具體可以看下圖:

1位	62	0 - 61
2位	3844	62 - 3843
3位	約 23萬(wàn)	3844 - 238327
4位	約 1400萬(wàn)	238328 - 14776335
5位	約 9.1億	14776336 - 916132831
6位	約 568億	916132832 - 56800235583
二.Hash算法

第一種方式:

簡(jiǎn)單的對(duì)長(zhǎng)鏈接進(jìn)行加鹽md5,會(huì)生成一個(gè)32位的字符串,隨機(jī)從里面取6個(gè)字符,或者簡(jiǎn)單粗暴取最后6位,但是md5只包含0-9A-Fa-f,比字母表的里面字符還少,沖突幾率更大!

第二種方式:

1.將長(zhǎng)網(wǎng)址 md5 生成 32 位簽名串,分為 4 段, 每段 8 個(gè)字節(jié)

2.對(duì)這四段循環(huán)處理, 取 8 個(gè)字節(jié), 將他看成 16 進(jìn)制串與 0x3fffffff(30位1) 與操作, 即超過(guò) 30 位的忽略處理

3.這 30 位分成 6 段, 每 5 位的數(shù)字作為字母表的索引取得特定字符, 依次進(jìn)行獲得 6 位字符串

4.總的 md5 串可以獲得 4 個(gè) 6 位串,取里面的任意一個(gè)就可作為這個(gè)長(zhǎng) url 的短 url 地址

生成的方式更加復(fù)雜,重復(fù)的幾率低,但是依然會(huì)出現(xiàn)沖突!

三.隨機(jī)數(shù)算法

這個(gè)更簡(jiǎn)單,直接對(duì)這個(gè)62個(gè)字符數(shù)組做隨機(jī)選擇,選擇其中6個(gè)字符當(dāng)作短鏈接碼,簡(jiǎn)單易用,但是難免會(huì)出現(xiàn)重復(fù)沖突!

四.算法對(duì)比

第一種算法只要解決自增id問(wèn)題就可以避免沖突,自增id可以采用數(shù)據(jù)庫(kù)自增主鍵,每次生成短碼只需一次數(shù)據(jù)庫(kù)操作(insert操作,獲取主鍵id,然后算出短碼即可)

第二種和第三種算法其實(shí)都差不多,都是依賴于程序隨機(jī),容易出現(xiàn)沖突,這就需要每次在插入數(shù)據(jù)庫(kù)的時(shí)候判重,效率低一些!

5.安全

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

所以不建議使用短鏈接發(fā)送具有私密性的網(wǎng)址,比如說(shuō)重置密碼鏈接,對(duì)一些權(quán)限、敏感信息的鏈接要做好二次鑒權(quán)!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/6909.html

相關(guān)文章

  • ELSE 技術(shù)周刊(2017.11.27期)

    摘要:而且已開源出來(lái),隨著容器技術(shù)發(fā)展,大文件分發(fā)一直是個(gè)重要的問(wèn)題,所以是一件值得研究的技術(shù)。實(shí)用推薦檢定攻略是近期推出的一項(xiàng)認(rèn)證,用以認(rèn)證開發(fā)者的移動(dòng)網(wǎng)頁(yè)開發(fā)技能。凈化,移除中不必要的文件技術(shù)周刊由小組出品,匯聚一周好文章,周刊原文。 業(yè)界動(dòng)態(tài) 直擊阿里雙11神秘技術(shù):PB級(jí)大規(guī)模文件分發(fā)系統(tǒng)蜻蜓 文章主要介紹了阿里的PB級(jí)大規(guī)模文件分發(fā)系統(tǒng)蜻蜓, 通過(guò)使用P2P技術(shù)同時(shí)結(jié)合智能壓縮、智...

    xushaojieaaa 評(píng)論0 收藏0
  • 鏈接原理分析

    摘要:舉個(gè)例子,第一個(gè)進(jìn)來(lái)的鏈接發(fā)號(hào)器發(fā)號(hào),對(duì)應(yīng)的短鏈接為,第二個(gè)進(jìn)來(lái)的鏈接發(fā)號(hào)器發(fā)號(hào),對(duì)應(yīng)的短鏈接為,以此類推。這樣一來(lái)會(huì)導(dǎo)致一條長(zhǎng)鏈接對(duì)應(yīng)多條短鏈接的情況出現(xiàn),不僅浪費(fèi)存儲(chǔ)空間,又浪費(fèi)發(fā)號(hào)器資源。 1. 什么是短鏈接 顧名思義,短鏈接即是長(zhǎng)度較短的網(wǎng)址。通過(guò)短鏈接技術(shù),我們可以將長(zhǎng)度較長(zhǎng)的鏈接壓縮成較短的鏈接。并通過(guò)跳轉(zhuǎn)的方式,將用戶請(qǐng)求由短鏈接重定向到長(zhǎng)鏈接上去。短鏈接主要用在諸如微博...

    SexySix 評(píng)論0 收藏0
  • 前端有用的網(wǎng)址介紹

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

    legendmohe 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<