<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
今天小編就帶著大家來盤點一下資料抓取過程中這些主流的加密演演算法,它們有什麼特徵、加密的方式有哪些等等,知道了這些之後對於我們逆向破解這些加密的引數會起到不少的幫助!
相信大家在資料抓取的時候,會碰到很多加密的引數,例如像是"token"、"sign"等等,今天小編就帶著大家來盤點一下資料抓取過程中這些主流的加密演演算法,它們有什麼特徵、加密的方式有哪些等等,知道了這些之後對於我們逆向破解這些加密的引數會起到不少的幫助!
首先我們需要明白的是,什麼是加密和解密?顧名思義
加密和解密演演算法的操作通常都是在一組金鑰的控制下進行的,分別成為是加密金鑰(Encryption Key)和解密金鑰(Decryption Key),
如下圖所示:
而加密演演算法當中又分為是對稱加密和非對稱加密以及雜湊演演算法,其中
Base64嚴格意義上來說不算做事加密的演演算法,只是一種編碼的方式,它是一種用64個字元,分別是A-Z、a-z、0-9、+、/這64個字元,實現對資料的編碼,可用於在HTTP環境下傳遞較長的標識資訊。採用Base64編碼具有不可讀性,需要解碼後才能閱讀。我們使用Python來對任意網址進行Base64的編碼操作,程式碼如下:
import base64 # 想將字串轉編碼成base64,要先將字串轉換成二進位制資料 url = "www.baidu.com" bytes_url = url.encode("utf-8") str_url = base64.b64encode(bytes_url) # 被編碼的引數必須是二進位制資料 print(str_url)
輸出:
b'd3d3LmJhaWR1LmNvbQ=='
那麼同樣地,我們也可以對其進行解碼的操作,程式碼如下:
url = "d3d3LmJhaWR1LmNvbQ==" str_url = base64.b64decode(url).decode("utf-8") print(str_url)
輸出:
www.baidu.com
MD5是一種被廣泛使用的線性雜湊演演算法,且加密之後產生的是一個固定長度(32位元或者是16位元)的資料,由字母和數位組成,大小寫統一。其最後加密生成的資料是不可逆的,也就是說不能夠輕易地通過加密後的資料還原到原始的字串,除非是通過暴力破解的方式。
我們在Python當中來實現一下MD5加密:
import hashlib str = 'this is a md5 demo.' hl = hashlib.md5() hl.update(str.encode(encoding='utf-8')) print('MD5加密前為 :' + str) print('MD5加密後為 :' + hl.hexdigest())
輸出:
MD5加密前為 :this is a md5 demo.
MD5加密後為 :b2caf2a298a9254b38a2e33b75cfbe75
就像上文提到的,針對MD5加密可以通過暴力破解的方式來降低其安全性,因此在實操過程當中,我們會新增鹽值(Salt)或者是雙重MD5加密等方式來增加其可靠性,程式碼如下:
# post傳入的引數 params = "123456" # 加密後需拼接的鹽值(Salt) salt = "asdfkjalksdncxvm" def md5_encrypt(): m = md5() m.update(params.encode('utf8')) sign1 = m.hexdigest() return sign1 def md5_encrypt_with_salt(): m = md5() m.update((md5_encrypt() + salt).encode('utf8')) sign2 = m.hexdigest() return sign2
首先我們來講DES加密,全稱是Data Encryption Standard,即資料加密標準,在對稱性加密當中比較常見的一種,也就是加密和解密過程當中使用的金鑰是相同的,因此想要破解的話,通過暴力列舉的方式,只要計算的能力足夠強還是可以被破解的。
AES的全稱是Advanced Encryption Standard,是DES演演算法的替代者,也是當今最流行的對稱加密演演算法之一。想要弄清楚AES演演算法,首先就得弄明白三個基本的概念:金鑰、填充和模式。
金鑰我們之前已經說了很多了,大家可以將其想象成是一把鑰匙,既可以用其來進行上鎖,可以用其來進行解鎖。AES支援三種長度的金鑰:128位元、192位以及256位。
而至於填充這一概念,AES的分組加密的特性我們需要了解,具體如下圖所示:
簡單來說,AES演演算法在對明文加密的時候,並不是把整個明文一股腦兒地加密成一整段密文,而是把明文拆分成一個個獨立的明文塊,每一個明文塊的長度為128位元。
這些明文塊經過AES加密器的複雜處理之後,生成一個個獨立的密文塊,將這些密文塊拼接到一起就是最終的AES加密的結果了。
那麼這裡就有一個問題了,要是有一段明文的長度是196位元,如果按照每128位元一個明文塊來拆分的話,第二個明文塊只有64位元了,不足128位元該怎麼辦呢?這個時候就輪到填充來發揮作用了,預設的填充方式是PKCS5Padding以及ISO10126Padding。
不過在AES加密的時候使用了某一種填充方式,解密的時候也必須採用同樣的填充方式。
AES的工作模式,體現在了把明文塊加密成密文塊的處理過程中,主要有五種不同的工作模式,分別是CBC、ECB、CTR、CFB以及OFB模式,同樣地,如果在AES加密過程當中使用了某一種工作模式,解密的時候也必須採用同樣地工作模式。最後我們用Python來實現一下AES加密。
import base64 from Crypto.Cipher import AES def AES_encrypt(text, key): pad = 16 - len(text) % 16 text = text + pad * chr(pad) text = text.encode("utf-8") encryptor = AES.new(key.encode('utf-8'), AES.MODE_ECB) encrypt_text = encryptor.encrypt(text) encrypt_text = base64.b64encode(encrypt_text) return encrypt_text.decode('utf-8')
到此這篇關於盤點Python 爬蟲中的常見加密演演算法的文章就介紹到這了,更多相關Python 加密演演算法內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45