Openssl生成RSA公私钥以及将公钥转换成C#支持的格式

1.RSA算法介绍

RSA算法是一种非对称密码算法,所谓非对称,就是指该算法需要一对密钥,使用其中一个加密,则需要用另一个才能解密。RSA的算法涉及三个参数,n、e、d。其中,n是两个大质数p、q的积,n被称为模数,n的二进制表示时所占用的位数,就是所谓的密钥长度。e和d是一对相关的值,e被称为公钥指数,e的值可以任意取,但要求e与(p-1)*(q-1)互质(X.509标准中建议采用65537);d被称为私钥指数,d的值要求满足(d×e)≡1(mod(p-1)×(q-1))。(n,e)两个数作为公钥使用,(n,d)两个数作为私钥使用。

RSA加解密的算法完全相同,设A为明文,B为密文,则:B=A^e(mod n)被称为加密运算;A=B^d(mod n)被称为解密运算。

2.生成私钥文件

可以通过OpenSSL的genrsa程序生成私钥文件,调用命令如下:

openssl genrsa -out key.pem 1024

生成文件名为key.pem,密钥长度为1024的私钥文件,私钥文件同时包含了RSA公钥和私钥两部分。

私钥文件内容如下图所示:

3.将私钥文件转换为公钥文件

可以通过OpenSSL的genrsa程序生成私钥文件,调用命令如下:openssl rsa -in key.pem -pubout -out pubkey.pem 公钥文件包含RSA公钥,即模数n和公钥指数e。

公钥文件内容如下图所示:

4.提取出私钥文件中的模,转化为C#支持的XML文件

C#有一个System.Security.Cryptography模块可以执行RSA加解密运算,可以通过XElement publickeyFromFile = XElement.Load(@"pubkey.xml")方法载入XML格式保存的RSA公钥。我编写了一个Python脚本,从前面生成的私钥文件提取出XML保存的RSA公钥。代码如下所示:

#!/usr/bin/python
#coding:utf-8 import os
import sys
import base64 '''
用Openssl生成服务器私钥文件,
并将公钥变成C#可以使用的xml格式文件
''' def main(): filepath = "/var/key.pem"
fd_pubkey = open("/var/pubkey.xml", "w")
os.system("/usr/bin/openssl genrsa -out %s 1024 >/dev/null 2>&1" %filepath)
# print filepath
# 提取公钥文件的模
# modulus = os.popen("/usr/bin/openssl rsa -in %s -pubin -modulus -noout" %filepath).read()
# 提取私钥文件的模
modulus = os.popen("/usr/bin/openssl rsa -in %s -modulus -noout" %filepath).read()
# print modulus
modulus1=modulus.split("=", 1)[1].strip()
st=[]
for i in range(len(modulus1)/2):
st.append(int(modulus1[i*2:(i+1)*2], 16))
st1=[]
for i in st:
st1.append(chr(i)) st1=''.join(st1)
modulus2=base64.b64encode(st1)
# print modulus2
exp="AQAB"
RSAKey="<RSAKeyValue><Modulus>"+modulus2+"</Modulus><Exponent>"+exp+"</Exponent></RSAKeyValue>"
fd_pubkey.write(RSAKey)
return 0 if __name__=='__main__':
sys.exit(main())

生成的XML文件如下所示:

<RSAKeyValue><Modulus>t0DhW51Tw8nWkmkO/3+Zlzf1f/DwKwAhS/nh7a/eoICCfMXV4BDUN9iZ6Kjo5KhdSMuedBdBXEM8bmhB5TEEF/4wdNkqt4hkooLRwA81XGjE9vcidEbfdm5CTU/nRSbBLm25ZaRdfmx0T5u1AiUsDyR3cNeqzH++Fh150Sbb9Y0=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>

其中AQAB对应公钥指数65537的BASE64编码值。

Openssl生成RSA公私钥以及将公钥转换成C#支持的格式的更多相关文章

  1. openssl生成rsa公私钥

    1.生成私钥pem,  执行命令openssl genrsa -out rsa_private_key.pem 1024 2.生成公钥,执行命令openssl rsa -in rsa_private_ ...

  2. openssl生成rsa公私钥对并在java中使用

    rsa著名的非对称加密算法,具体实现我也不是很清楚,大概先要了解一下密码学,有一定基础才能去看的东东,这里就先介绍怎么使用rsa为我们服务. 首先openssl这是个集成了众多加密算法的工具,它将这一 ...

  3. OpenSSL生成RSA公私钥(java)

    生成私钥:genrsa -out rsa_private_key.pem 1024 生成公钥:rsa -in rsa_private_key.pem -out rsa_public_key.pem - ...

  4. java生成RSA公私钥字符串,简单易懂

    java生成RSA公私钥字符串,简单易懂   解决方法: 1.下载bcprov-jdk16-140.jar包,参考:http://www.yayihouse.com/yayishuwu/chapter ...

  5. NetCore 生成RSA公私钥对,公钥加密私钥解密,私钥加密公钥解密

    using Newtonsoft.Json; using Org.BouncyCastle.Crypto; using Org.BouncyCastle.Crypto.Encodings; using ...

  6. Windows 下使用OpenSSL生成RSA公钥和私钥

    Windows 下使用OpenSSL生成RSA公钥和私钥 (1)下载OpenSSL 可到该地址下载OpenSSL: https://www.openssl.org/source/(https://ww ...

  7. openssl生成RSA密钥证书

    1.openssl的安装 2.RSA密钥证书的生成 3.openssl的常用命令 1.openssl的安装 openssl 是目前最流行的 SSL 密码库工具,其提供了一个通用.健壮.功能完备的工具套 ...

  8. 如何使用openssl生成RSA公钥和私钥对

      在ubuntu上要使用openssl的话需要先进行安装,命令如下: sudo apt-get install openssl 安装完成就可以使用openssl了. 首先需要进入openssl的交互 ...

  9. 在Linux下如何使用openssl生成RSA公钥和私钥对

    在<Java实现RSA密钥对并在加解密.加签验签中应用的实例>中,我们有用Java代码生成RSA密钥对,其实在Linux操作系统中,用openssl也是很容易生成密钥对的. 一.如果在ub ...

随机推荐

  1. Linux下Redis的安装和部署 详细

    一.Redis介绍 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类型相对更多 ...

  2. NOIP 2011 Mayan游戏 大暴搜

    题目链接:https://www.luogu.org/problemnew/show/P1312 我的第一篇题解!! 当然感谢ZAGER 的提示,他的链接https://www.cnblogs.com ...

  3. Vsftpd软件包的获取与安装

    11.2  Vsftpd简介 Vsftpd是一种在GPL许可下开放源代码的FTP服务器,用于多种UNIX系统和Linux系统.Vsftpd也称为Very Secure FTP Daemon,它是一种安 ...

  4. E20180127-hm

    retain  vt. 保持; 留在心中,记住; 雇用; 付定金保留;

  5. c#自定义ORM框架---(泛型&反射&实体类扩展属性<附带通用增、删、查、改>)

    该教材主要是运用到泛型.反射和实体类扩展属性 步骤一.建立扩展属性类 实体类扩展属性要继承Attribute基类完成 [AttributeUsage(AttributeTargets.Property ...

  6. ASP.Net 知识点总结(五)

    1.传入某个属性的set方法的隐含参数的名称是什么?value,它的类型和属性所声名的类型相同.2.如何在C#中实现继承? 在类名后加上一个冒号,再加上基类的名称.3.C#支持多重继承么? 不支持.可 ...

  7. RabbitMQ的一些基本操作

    $ sudo chkconfig rabbitmq-server on # 添加开机启动RabbitMQ服务 $ sudo /sbin/service rabbitmq-server start # ...

  8. [Qt Creator 快速入门] 第8章 界面外观

    一个完善的应用程序不仅应该有实用的功能,还要有一个漂亮的外观,这样才能使应用程序更加友好,更加吸引用户.作为一个跨平台的UI开发框架,Qt提供了强大而灵活的界面外观设计机制.这一章将学习在Qt中设计应 ...

  9. [C和指针] 1-快速上手、2-基本概念、3-数据

    第1章 快速上手 1.1.1 空白和注释   程序的空白的作用: 空行将程序的不同部分分割开来:制表符缩进语句,可以更好地显示程序的结构等等.     软件最大的开销并非在于编写,而是在于维护,所以需 ...

  10. 分布式爬虫系统设计、实现与实战:爬取京东、苏宁易购全网手机商品数据+MySQL、HBase存储

    http://blog.51cto.com/xpleaf/2093952 1 概述 在不用爬虫框架的情况,经过多方学习,尝试实现了一个分布式爬虫系统,并且可以将数据保存到不同地方,类似MySQL.HB ...