幾乎所有的微薄都提供了縮短網(wǎng)址的服務(wù),其原理就是將一個url地址按照一定的算法生成一段字符串,然后加在一個短域名后面邊成了一個新的url地址,數(shù)據(jù)庫中會存放這個短地址和原始的地址,當(dāng)用戶點擊這個新的短地址后,短地址服務(wù)會根據(jù)短域名后面的幾個字符串從數(shù)據(jù)庫中讀出原來的地址然后頁面進(jìn)行跳轉(zhuǎn) 。
比如新浪微薄中的url 是 http://t.cn/xxxxxxx? t.cn是其域名 ,其后面跟著的是7位算出來的字符串。
方法一:使用哈希庫自定義算法
因為文本中顯示太長的url會比較亂,或者采用省略顯示的方式,或者采用短url的方式.
為了同時方便統(tǒng)計點擊數(shù)以及進(jìn)行內(nèi)容過濾.實現(xiàn)了一個生成短url值的方法.
為了防止你的hash值被破解,可以在生成md5值的時候加入你自己的salt.
這樣即便直到你的code_map也不能破解到原始url了.
為了讓結(jié)果更加隨機,把每次循環(huán)沒有使用的第二個bit保存到e里面.這樣可以讓結(jié)果沖突率更小.
#引入哈希庫 import hashlib def get_md5(s): s = s.encode('utf8') if isinstance(s, unicode) else s m = hashlib.md5() m.update(s) return m.hexdigest() code_map = ( 'a' , 'b' , 'c' , 'd' , 'e' , 'f' , 'g' , 'h' , 'i' , 'j' , 'k' , 'l' , 'm' , 'n' , 'o' , 'p' , 'q' , 'r' , 's' , 't' , 'u' , 'v' , 'w' , 'x' , 'y' , 'z' , '0' , '1' , '2' , '3' , '4' , '5' , '6' , '7' , '8' , '9' , 'A' , 'B' , 'C' , 'D' , 'E' , 'F' , 'G' , 'H' , 'I' , 'J' , 'K' , 'L' , 'M' , 'N' , 'O' , 'P' , 'Q' , 'R' , 'S' , 'T' , 'U' , 'V' , 'W' , 'X' , 'Y' , 'Z' ) def get_hash_key(long_url): hkeys = [] hex = get_md5(long_url) for i in xrange(0, 4): n = int(hex[i*8:(i+1)*8], 16) v = [] e = 0 for j in xrange(0, 5): x = 0x0000003D & n e |= ((0x00000002 & n ) >> 1) << j v.insert(0, code_map[x]) n = n >> 6 e |= n << 5 v.insert(0, code_map[e & 0x0000003D]) hkeys.append(''.join(v)) return hkeys if __name__ == '__main__': print get_hash_key('http://www.pythontab.com')
方法二:使用libsurl庫
libsurl 是一個用來生成短URL的C和Python庫,支持 bit.ly 和 tinyurl 等短url 服務(wù)網(wǎng)站。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
