使http传输更加安全,c/s b/s架构的加密通信。
PySecureHTT的Python项目详细描述
通过使用RSA+AES让HTTP传输更加安全,即C/S架构的加密通信!(Make HTTP transmissions more secure via RSA+AES, encrypted communication for C/S architecture.)
使用概述(Overview)
安装(Installation):
# 正式版(Release) $ pip install -U PySecureHTTP # 开发版(Dev) $ pip install -U git+git+https://github.com/cisco08/PythonWeb-SecureHTTP@master
示例代码(Examples):
AES加密、解密
fromSecureHTTPimportAESEncrypt,AESDecrypt# 加密后的密文ciphertext=AESEncrypt('ThisIsASecretKey','Hello World!')# 解密后的明文plaintext=AESDecrypt("ThisIsASecretKey",ciphertext)
RSA加密、解密
fromSecureHTTPimportRSAEncrypt,RSADecrypt,generate_rsa_keys# 生成密钥对(pubkey,privkey)=generate_rsa_keys(incall=True)# 加密后的密文ciphertext=RSAEncrypt(pubkey,'Hello World!')# 解密后的明文plaintext=RSADecrypt(privkey,ciphertext)
C/S加解密示例:
# 模拟C/S请求fromSecureHTTPimportEncryptedCommunicationClient,EncryptedCommunicationServer,generate_rsa_keyspost={u'a':1,u'c':3,u'b':2,u'data':["a",1,None]}resp={u'msg':None,u'code':0}# 生成密钥对(pubkey,privkey)=generate_rsa_keys(incall=True)# 初始化客户端类client=EncryptedCommunicationClient(pubkey)# 初始化服务端类server=EncryptedCommunicationServer(privkey)# NO.1 客户端加密数据c1=client.clientEncrypt(post)# NO.2 服务端解密数据s1=server.serverDecrypt(c1)# NO.3 服务端返回加密数据s2=server.serverEncrypt(resp)# NO.4 客户端获取返回数据并解密c2=client.clientDecrypt(s2)# 以上四个步骤即完成一次请求/响应
说在后面(END)
欢迎提交PR、共同开发!