python3中rsa加密算法詳情
前言:
rsa加密,是一種加密算法,目前而言,加密算法,是對數據、密碼等進行加密。第一次接觸rsa加密算法是linux中免密登陸設置,當時一直以為密鑰加密是像token一樣的,直到現在才發現並不是,而是一種數據加密的方式,其實也可以理解,在Linux設計哲學的理解下:“一切皆文件”,就可以把他們當成類似的東西來理解。無非就是拿著a字符串和b字符串進行比較,如果返回trun,那麼就可以進行下一步的操作,否則就會被返回異常。
在這裡,其實有一個邏輯,就是先把數據進行一次加密,然後進行數據傳輸,在接收到數據後,發現數據是亂碼,或者說是加密過後的數據,所以想要看到實際數據,就需要對數據進行解密。
所以在常規的加密過程中,許多接口中的數據我們是已經可以獲取到的,但是獲取到的數據是亂碼,一般如果想要繼續增加安全性,就可以在獲取數據的時候加簽,即在給訪問接口的服務返回數據時,就進行驗證,在他發送接收數據請求時,就拒絕他。
也就是說,目前的接口加密,其實是從兩個點出發:
- 一、接收數據請求時(數據返回前)
- 二、數據本身加密(數據返回後)(如果請求,就把數據返回,但是我賭的是他拿到數據也不會解讀出來。狗頭)
就目前而言,我所能想到的加密方案,也都是對字符串加密,或者對一些標識符進行加密,也就是發生在數據返回前所發生的事件。不知道別的大佬還有沒有別的騷操作。
技術測試實現:
在這裡使用rsa包直接進行,python第三方庫實現加密的還有一個pycryptodome,兩個包都可以實現。在這裡使用rsa。
代碼邏輯簡單說一下,也做瞭幾個測試:
- 一、直接生成密鑰,然後進行加密,解密,
- 二、先生成密鑰,然後將密鑰寫入文件保留下來,然後再讀出來使用
- 三、直接生成密鑰,然後將密鑰寫成字符串,放在代碼中,直接使用
上述三種,其實從邏輯上講,都應該是支持的,如果不支持,那麼就應該是過程中某個地方的格式有問題。需要進行常規處理。
在使用過程中,有一個地方需要特別註意,就是需要加密的字符串要進行encoding,在解密是需要進行decode。不要忘記這一點。否則你會發現加密時就會報錯。
import rsa def secorty_data(): (pub_key,sec_key) = rsa.newkeys(1024) pub = pub_key.save_pkcs1() file = open('./pub.pem','wb+') file.write(pub) sec = sec_key.save_pkcs1() files = open('./sec.pem','wb+') files.write(sec) def create_rsa(): file = open('./pub.pem','rb') content = file.read() print(content) file1 = open('./sec.pem','rb') content1 = file1.read() print(content1) pub_key = rsa.PublicKey.load_pkcs1(content) sec_key = rsa.PrivateKey.load_pkcs1(content1) message = '今天的天氣有點熱,但整體還是很好' data = rsa.encrypt(message.encode(),pub_key) print(data) result = rsa.decrypt(data,sec_key) print(result.decode()) if __name__ == '__main__': secorty_data() create_rsa()
到此這篇關於python3中rsa加密算法詳情的文章就介紹到這瞭,更多相關 rsa加密 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 使用python加密主機文件幾種方法實現
- Python使用os模塊實現更高效地讀寫文件
- Python中json.load()和json.loads()有哪些區別
- python必學知識之文件操作(建議收藏)
- 如何使用python批量修改文本文件編碼格式