日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python下RSA加密解密以及跨平台问题

發布時間:2024/4/17 python 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python下RSA加密解密以及跨平台问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

項目合作需要,和其他網站通信,消息內容采用RSA加密方式傳遞。之前沒有接觸過RSA,于是兩個問題出現了:

聲明: 環境WIN 7 + python 2.6.6 RSA格式:PEM

一、Python下RSA加密解密怎么做? 現在網上搜索關于RSA的信息,然后看一下Python下是怎么做的。

找到兩種方法:

1、使用rsa庫 安裝

pip install rsa

可以生成RSA公鑰和密鑰,也可以load一個.pem文件進來。

1 # -*- coding: utf-8 -*- 2 __author__ = 'luchanghong' 3 import rsa 4 5 # 先生成一對密鑰,然后保存.pem格式文件,當然也可以直接使用 6 (pubkey, privkey) = rsa.newkeys(1024) 7 8 pub = pubkey.save_pkcs1() 9 pubfile = open('public.pem','w+') 10 pubfile.write(pub) 11 pubfile.close() 12 13 pri = privkey.save_pkcs1() 14 prifile = open('private.pem','w+') 15 prifile.write(pri) 16 prifile.close() 17 18 # load公鑰和密鑰 19 message = 'hello' 20 with open('public.pem') as publickfile: 21 p = publickfile.read() 22 pubkey = rsa.PublicKey.load_pkcs1(p) 23 24 with open('private.pem') as privatefile: 25 p = privatefile.read() 26 privkey = rsa.PrivateKey.load_pkcs1(p) 27 28 # 用公鑰加密、再用私鑰解密 29 crypto = rsa.encrypt(message, pubkey) 30 message = rsa.decrypt(crypto, privkey) 31 print message 32 33 # sign 用私鑰簽名認真、再用公鑰驗證簽名 34 signature = rsa.sign(message, privkey, 'SHA-1') 35 rsa.verify('hello', signature, pubkey)

?

2、使用M2Crypto python關于RSA的庫還是蠻多的,當然也可以直接用openSSL。M2Crypto安裝的時候比較麻煩,雖然官網有exe的安裝文件,但是2.6的有bug,建議使用0.19.1版本,最新的0.21.1有問題。

1 # -*- coding: utf-8 -*- 2 __author__ = 'luchanghong' 3 from M2Crypto import RSA,BIO 4 5 rsa = RSA.gen_key(1024, 3, lambda *agr:None) 6 pub_bio = BIO.MemoryBuffer() 7 priv_bio = BIO.MemoryBuffer() 8 9 rsa.save_pub_key_bio(pub_bio) 10 rsa.save_key_bio(priv_bio, None) 11 12 pub_key = RSA.load_pub_key_bio(pub_bio) 13 priv_key = RSA.load_key_bio(priv_bio) 14 15 message = 'i am luchanghong' 16 17 encrypted = pub_key.public_encrypt(message, RSA.pkcs1_padding) 18 decrypted = priv_key.private_decrypt(encrypted, RSA.pkcs1_padding) 19 20 print decrypted

?

用法差不多一致。load密鑰的方式也有好幾種。 二、跨平臺密鑰不統一 RSA加密驗證搞定了,但是和java平臺交互的時候出問題,java生成的密鑰用Python根本load不了,更別說加密了,反之Java也load不了Python生成的密鑰。 上網查找原因,RSA認真流程肯定沒有問題,關鍵是不同平臺執行RSA的標準有些偏差。 ?

轉載于:https://www.cnblogs.com/luchanghong/archive/2012/07/18/2596886.html

總結

以上是生活随笔為你收集整理的python下RSA加密解密以及跨平台问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。