OpenSSL使用指南之指南【转载内容】

OpenSSL Org

 

OpenSSL使用指南

from:http://findingjob.blog.sohu.com/234214852.html。thx ~ “我的奋斗”!

1     介绍

OpenSSL是使用非常广泛的SSL的开源实现。由于其中实现了为SSL所用的各种加密算法,因此OpenSSL也是被广泛使用的加密函数库。< XMLNAMESPACE PREFIX ="O" />

1.1   SSL

SSL(Secure Socket Layer)安全协议是由Netscape公司首先提出,最初用在保护Navigator浏览器和Web服务器之间的HTTP通信(HTTPS)。后来SSL协议成为传输层安全通信事实上的标准,并被IETF吸收改进为TLS(Transport Layer Security)协议。

SSL/TLS协议位于TCP协议和应用层协议之间,为传输双方提供认证、加密和完整性保护等安全服务。SSL作为一个协议框架,通信双方可以选用合适的对称算法、公钥算法、MAC算法等密码算法实现安全服务。

1.2   OpenSSL

OpenSSL是著名的SSL的开源实现,是用C语言实现的。

OpenSSL的前身是SSLeay,一个由Eric Young开发的SSL的开源实现,支持SSLv2/v3TLSv1

伴随着SSL协议的普及应用,OpenSSL被广泛应用在基于TCP/Socket的网络程序中,尤其是OpenSSLApache相结合,是很多电子商务网站服务器的典型配置。

2     编译和安装OpenSSL

OpenSSL开放源代码,这对学习、分析SSL和各种密码算法提供了机会,也便于在上面进一步开发。

2.1   获取OpenSSL

OpenSSL的网站即可下载当前版本的OpenSSL源代码压缩包。

当前版本openssl-< XMLNAMESPACE PREFIX ="ST1" />0.9.8.tar.gz,只有3M多,比较精简。解压缩后得到一个目录openssl-0.9.8,共有约1800个文件,15M。其中crypto子目录中是众多密码算法实现,ssl子目录中是SSL协议的实现。

Linux中解压缩:

$tar zxf openssl-0.9.8.tar.gz

Windows中可以使用winzipwinrar解压。

2.2   编译工具

编译OpenSSL需要PerlC编译器。在Windows下如果要用加密算法的汇编代码实现,还需要masmnasm汇编器。(汇编代码可以比C代码显著提高密码运算速度)

PerlWindows下推荐使用Active Perl

C编译器可以使用gcc。在Windows下可以使用visual C++编译

汇编器推荐使用nasm

这些工具所在目录必须加入到PATH环境变量中去。

2.3   编译与安装步骤

查看readme是个好习惯。从readme了解到需要进一步查看INSTALLINSTALL.W32文件。

Windows中:

>perl Configure VC-WIN32

>ms\do_nasm(如果不使用汇编代码实现,则可>ms\do_ms)

>nmake -f ms\ntdll.mak

>cd out32dll

>..\ms\test

编译结果得到头文件、链接库、运行库和openssl.exe工具。头文件位于./inc32或者./inculde目录,有一个openssl子目录,内有几十个.h文件。链接库即./out32dll目录中的libeay32.lib ssleay32.lib,分别是密码算法相关的和ssl协议相关的。运行库是./out32dll目录中的libeay32.dll ssleay32.dll,和链接库相对应。在./out32dll中还有一个工具openssl.exe,可以直接用来测试性能、产生RSA密钥、加解密文件,甚至可以用来维护一个测试用的CA

Linux中的编译和安装步骤较简单:

$./config

$make

$make test

$make install

Linux下,头文件、库文件、工具都已被安装防盗了合适的位置。库文件是.a.so格式。

3 使用Openssl.exe

使用OpenSSL.exe(Linux中可执行文件名是openssl)可以做很多工作,是一个很好的测试或调试工具。

3.1 版本和编译参数

显示版本和编译参数: >openssl version –a

3.2 支持的子命令、密码算法

查看支持的子命令: >openssl ?

SSL密码组合列表: >openssl ciphers

3.3 测试密码算法速度

测试所有算法速度: >openssl speed

测试RSA速度: >openssl speed rsa

测试des速度: >openssl speed des

3.4 RSA密钥操作

产生RSA密钥对: >openssl genrsa –out 1.key 1024

取出RSA公钥: >openssl rsa –in 1.key –pubout –out 1.pubkey

3.5 加密文件

加密文件: >openssl enc –e –rc4 –in 1.key –out 1.key.enc

解密文件: >openssl enc –d –rc4 –in 1.key.enc –out 1.key.dec

3.6 计算Hash

计算文件的MD5值: >openssl md5 < 1.key

计算文件的SHA1值: >openssl sha1 < 1.key

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值