OpenSSL是用于安全通信的著名开源密码学工具包,包括主要的密码算法、常见密码和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。
OpenSSL整个软件包大概可以分成三个主要的功能部分:密码算法库、SSL协议库以及应用程序。OpenSSL的目录结构自然也是围绕这三个功能部分进行规划的。
官方源下载地址: https://www.openssl.org/source/
OpenSSL有两种运行模式:交互模式和批处理模式。
直接输入openssl回车进入交互模式,输入带命令选项的openssl进入批处理模式。
对称加密算法
OpenSSL一共提供了8种对称加密算法,其中7种是分组加密算法,仅有的一种流加密算法是RC4
。这7种分组加密算法分别是AES
、DES
、Blowfish
、CAST
、IDEA
、RC2
、RC5
,都支持电子密码本模式(ECB)、加密分组链接模式(CBC)、加密反馈模式(CFB)和输出反馈模式(OFB)四种常用的分组密码加密模式。其中,AES使用的加密反馈模式(CFB)和输出反馈模式(OFB)分组长度是128位,其它算法使用的则是64位。事实上,DES算法里面不仅仅是常用的DES算法,还支持三个密钥和两个密钥3DES算法。
非对称加密算法
OpenSSL一共实现了4种非对称加密算法,包括DH
算法、RSA
算法、DSA
算法和椭圆曲线算法(EC
)。DH算法一般用户密钥交换。RSA算法既可以用于密钥交换,也可以用于数字签名,当然,如果你能够忍受其缓慢的速度,那么也可以用于数据加密。DSA算法则一般只用于数字签名。
信息摘要算法
OpenSSL实现了5种信息摘要算法,分别是MD2
、MD5
、MDC2
、SHA(SHA1)
和RIPEMD
。SHA算法事实上包括了SHA和SHA1两种信息摘要算法,此外,OpenSSL还实现了DSS标准中规定的两种信息摘要算法DSS
和DSS1
。
密钥和证书管理
密钥和证书管理是PKI的一个重要组成部分,OpenSSL为之提供了丰富的功能,支持多种标准。
首先,OpenSSL实现了
ASN.1
的证书和密钥相关标准,提供了对证书、公钥、私钥、证书请求以及CRL
等数据对象的DER
、PEM
和BASE64
的编解码功能。OpenSSL提供了产生各种公开密钥对和对称密钥的方法、函数和应用程序,同时提供了对公钥和私钥的DER编解码功能。并实现了私钥的PKCS#12
和PKCS#8
的编解码功能。OpenSSL在标准中提供了对私钥的加密保护功能,使得密钥可以安全地进行存储和分发。
在此基础上,OpenSSL实现了对证书的X.509标准编解码、PKCS#12格式的编解码以及PKCS#7的编解码功能。并提供了一种文本数据库,支持证书的管理功能,包括证书密钥产生、请求产生、证书签发、吊销和验证等功能。
事实上,OpenSSL提供的CA应用程序就是一个小型的证书管理中心(CA),实现了证书签发的整个流程和证书管理的大部分机制。
请下载版本1.1.1系列,这个是最新的稳定版本,这也是openssl长期支持(LTS)的版本。
OpenSSL
官网没有提供windows版本的安装包,可以选择其他开源平台提供的工具。
一般在安装openssl之前还需要Visual Studio
的一些插件,该地址中也提供了相关插件的下载。如下图即为Openssl的安装及其Visual Studio插件在下载网页的截图。
安装步骤和使用方法如下:
openssl pkcs12 -export -out www.domain.com.pfx -inkey 2_www.domain.com.key -in 1_www.domain.com_cert.crt
例如key和crt文件保存在 D:\ ,运行情况如下:
Ps:Export Password不需要可以直接回车不进行输入。(如果没有设置密码)
此过程比较复杂,需要先安装perl、vs等软件,然后才能编译openssl。
相关网站:https://www.cnblogs.com/lpxblog/p/5382653.html
1. 下载并安装perl:
直接运行安装文件(例如:ActivePerl-5.16.3.1604-MSWin32-x86-298023.msi)即可完成安装;安装过程将自动完成环境变量的配置(安装完成之后,可以在系统环境变量里看到perl的bin目录(例如: C:\Program Files\perl\site\bin;)已经被加入进来),无需再手工配置;如果没有就需要自行配置一下。
进入perl安装目录的eg文件夹,执行“perl example.pl”若显示“Hello from ActivePerl!”,则说明Perl安装成功。
Perl安装成功之后就可以开始使用Perl的相关命令来进行OpenSSL的安装了。
…还在写中,其实就是搬运,排版…
1. 消息摘要算法应用例子
# openssl dgst -sha1 file.tx
# openssl sha1 -out digest.txt file.txt
# openssl dgst -dss1 -sign dsakey.pem -out dsasign.bin file.txt
# openssl dgst -dss1 -prverify dsakey.pem -signature dsasign.bin file.txt
# openssl sha1 -sign rsaprivate.pem -out rsasign.bin file.txt
# openssl sha1 -verify rsapublic.pem -signature rsasign.bin file.txt
2. 对称加密应用例子
# openssl enc -des3 -salt -in plaintext.doc -out ciphertext.bin
# openssl enc -des-ede3-ofb -d -in ciphertext.bin -out plaintext.doc -pass pass:trousers
# openssl bf-cfb -salt -in plaintext.doc -out ciphertext.bin -pass env:PASSWORD
# openssl base64 -in ciphertext.bin -out base64.txt
# openssl rc5 -in plaintext.doc -out ciphertext.bin -S C62CB1D49F158ADC -iv E9EDACA1BD7090C6 -K 89D4B1678D604FAA3DBFFD030A314B29
3. Diffie-Hellman应用例子
# openssl dhparam -out dhparam.pem -2 1024
# openssl dhparam -in dhparam.pem -noout -C
4. DSA应用例子应用例子
# openssl dsaparam -out dsaparam.pem 1024
# openssl gendsa -out dsaprivatekey.pem -des3 dsaparam.pem
# openssl dsa -in dsaprivatekey.pem -pubout -out dsapublickey.pem
# openssl dsa -in dsaprivatekey.pem -out dsaprivatekey.pem -des3 -passin
5. RSA应用例子
# openssl genrsa -out rsaprivatekey.pem -passout pass:trousers -des3 1024
# openssl rsa -in rsaprivatekey.pem -passin pass:trousers -pubout -out rsapubckey.pem
# openssl rsautl -encrypt -pubin -inkey rsapublickey.pem -in plain.txt -out cipher.txt
# openssl rsautl -decrypt -inkey rsaprivatekey.pem -in cipher.txt -out plain.txt
# openssl rsautl -sign -inkey rsaprivatekey.pem -in plain.txt -out signature.bin
# openssl rsautl -verify -pubin -inkey rsapublickey.pem -in signature.bin -out plain
# openssl smime -encrypt -in mail.txt -des3 -out mail.enc cert.pem
# openssl smime -decrypt -in mail.enc -recip cert.pem -inkey key.pem -out mail.txt
# openssl smime -sign -in mail.txt -signer cert.pem -inkey key.pem -out mail.sgn
# openssl smime -verify -in mail.sgn -out mail.txt
559666429
来(扫扫下面二维码或者点击群链接 Unity3D[ 交流&副业]CLUB ),大家一起找答案,共同进步。 同时欢迎各大需求商入住,发布自己的需求,给群内伙伴提供副职,赚取外快。对了,资源的话,要在群公告里面找。由于工作生活太忙了,对于大家的帮助时间已经没有之前那么充裕了。如果有志同道合的朋友,可以接受无偿的帮助别人,可以单独联系我,一块经营一下。
如果你有更好的经营方式也来练习我,加我QQ