项目合作需要,和其他网站通信,消息内容采用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加密解密以及跨平台问题相关推荐

  1. python实现RSA加密解密 及 签名验签功能

    本篇写一下python实现RSA的加密解密功能.私钥签名 公钥验签功能. 主要分三部分来介绍 生成私钥和公钥 脚本如下,运行后会生成public.pem(公钥) 和 private.pem(私钥) d ...

  2. python实现rsa加密解密代码_使用python实现rsa算法代码

    RSA算法是一种非对称加密算法,是现在广泛使用的公钥加密算法,主要应用是加密信息和数字签名. 维基百科给出的RSA算法简介如下: 假设Alice想要通过一个不可靠的媒体接收Bob的一条私人讯息.她可以 ...

  3. python实现rsa加密解密_python实现RSA加解密

    RSA的算法涉及三个参数,n.e.d. 其中,n是两个大质数p.q的积,n的二进制表示所占用的位数,就是所谓的密钥长度. e和d是一对相关的值,e可以任意取,但要求e与(p-1)*(q-1)互质:再选 ...

  4. android底层rsa加密,android 下RSA加密解密

    参考文章 Base64.java需要换成下面这个类 package club.hb168.hmi.util.rsa; import java.io.ByteArrayOutputStream; imp ...

  5. python rsa加密解密_RSA加密解密(python版)

    RSA的算法涉及三个参数,n.e.d. 其中,n是两个大质数p.q的积,n的二进制表示时所占用的位数,就是所谓的密钥长度. e1和d是一对相关的值,e可以任意取,但要求e与(p-1)*(q-1)互质: ...

  6. python加密解密 sha256_Python下实现的RSA加密/解密及签名/验证功能示例

    本文实例讲述了Python下实现的RSA加密/解密及签名/验证功能.分享给大家供大家参考,具体如下: 原文是py2环境,而我的环境是py3,所以对原代码做了修改:decode(), encode() ...

  7. python实现rsa加密源代码_python实现RSA加密(解密)算法

    RSA是目前最有影响力的公钥加密算法,它能够抵抗到目前为止已知的绝大多数密码攻击,已被ISO推荐为公钥数据加密标准. 今天只有短的RSA钥匙才可能被强力方式解破.到2008年为止,世界上还没有任何可靠 ...

  8. python rsa加密解密 字符串_python_rsa加密解密

    代码: #!/usr/bin/env python #encoding=utf-8 ''' 测试rsa加密解密 ''' from M2Crypto import RSA msg = 'aaaa-aaa ...

  9. MacOS下使用C语言基于openssl库进行RSA加密解密

    MacOS下使用C语言基于openssl库进行RSA加密解密 1 安装openssl并生成密钥 首先当然要安装openssl(这里记得看一下安装路径,应该是/usr/local/Cellar/open ...

最新文章

  1. mysql 主从有哪几种模式_mysql 主从模式总结(一)
  2. 面向自动驾驶领域的3D点云目标检测方法汇总!(单模态+多模态/数据+代码)
  3. MySQL5.1升级到5.5注意事项
  4. Swift3.0语言教程获得一个公共的前缀
  5. Dubbo将积极适配Spring Cloud生态,Spring Cloud体系或将成为微服务的不二选择!
  6. day03: oracle的sql增 、删、改,事务处理
  7. opengl加载显示3D模型X3D类型文件
  8. php递归删除文件,PHP 递归删除文件夹
  9. 深度特征融合--add和concat【转载】
  10. 优秀的代码永垂不朽!
  11. 核心交换机的TRUNK配置详细讲解
  12. 解决CentOS 6 字体变成方框的方法
  13. 如何通过 Redis 实现分布式锁
  14. 【学习进阶】Java 进阶学习资料《Java 编程思想》第5版 等
  15. Linux红帽认证管理员(RHCAS)考试笔记
  16. 【iOS】iOS8 与以前版本比较,添加的新特性
  17. 用Ajax+js+jQuery实现无闪烁定时刷新页面 定时刷新
  18. SAPGUI 里 F1 功能键的用法专题讲解试读版
  19. pdfjs 浏览器打印字体模糊问题
  20. C++的STL中accumulate的用法

热门文章

  1. 堆/栈/动态存储方式/静态存储方式
  2. [转]使用gazebo中的building editor创建一个建筑环境并用于仿真
  3. [BUUCTF-pwn]——picoctf_2018_shellcode
  4. Excel自定义函数使用正则表达式详解
  5. MySQL 存储过程的基本用法
  6. 安装maven到Eclipse
  7. SpringBoot的yml配置文件
  8. C#中读取带有Xmlns命名空间的XML文件
  9. input 模糊搜索
  10. VC++更改程序图标