openssl编程入门(含完整可编译和运行示例)

简介: OpenSSL编程入门(含完整示例).docOpenSSL编程入门(含完整示例).pdf OpenSSL编程入门(含完整示例) 易剑 2008/12/5 目录 目录 1 1.
img_e25d4fb2f8de1caf41a735ec53088516.pngOpenSSL编程入门(含完整示例).doc img_e25d4fb2f8de1caf41a735ec53088516.pngOpenSSL编程入门(含完整示例).pdf

OpenSSL编程入门(含完整示例)

易剑 2008/12/5

目录

目录 1

1. 编写目的 1

2. 示例包 1

3. 什么是SSL 2

4. 什么是openssl 2

5. 示例程序 2

6. 服务端编写步骤 3

7. 客户端编写步骤 4

8. 相关头文件 4

8.1. socket头文件 4

8.2. SSL头文件 4

9. 结尾 5

 

1. 编写目的

第一次跑起openssl示例并不太简单,本文的目的是为了让这个过程变得非常简单。在开始之前,要非常感谢周立发同学,正是通过他共享的示例,较轻松的入了门。

本文档对他共享的示例中的一个小错误进行了修正,并提供了傻瓜式的“编译-生成-KEY运行”一条龙脚本(方法请参见压缩包中的readme文件),让跑第一个openssl程序变得轻轻松松。

2. 示例包

img_e25d4fb2f8de1caf41a735ec53088516.pngssl_test.zip

ssl_test.tar.gz为示例源代码包,openssl-0.9.8h-SuSE10.tar.gzopenssl二进制包(因超过2M,不能作为附件下载,请上官网下载),测试时是安装在/usr/local/ssl

ssl_test.tar.gz中的示例在SuSE10中测试通过,使用的是openssl-0.9.8h,它包括如下文件:

-rw-r--r-- 1 root root 1346 Dec 5 18:11 cacert.pem

-rwxr-xr-x 1 root root 114 Dec 5 18:11 make_key.sh

-rwxr-xr-x 1 root root 172 Dec 5 18:37 mk_client.sh

-rwxr-xr-x 1 root root 172 Dec 5 18:37 mk_server.sh

-rw-r--r-- 1 root root 1679 Dec 5 18:11 privkey.pem

-rw-r--r-- 1 root root 167 Dec 5 18:39 readme

-rwxr-xr-x 1 root root 38 Dec 5 18:38 run_client.sh

-rwxr-xr-x 1 root root 64 Dec 5 18:38 run_server.sh

-rwxr-xr-x 1 root root 1140142 Dec 5 18:38 ssl_client

-rw-r--r-- 1 root root 3928 Dec 5 17:31 ssl_client.cpp

-rwxr-xr-x 1 root root 1139667 Dec 5 18:38 ssl_server

-rw-r--r-- 1 root root 4882 Dec 5 17:31 ssl_server.cpp

 

readme为包内容说明,run_server.sh用来运行服务端,run_client.sh用来运行客户端,mk_server.sh用来编译服务端,mk_client.sh用来编译客户端,make_key.sh用来生成钥匙KEY

3. 什么是SSL

在学习openssl编程之前,先了解一下什么是SSL,有助于后续的学习。SSL 是一个缩写,代表的是 Secure Sockets Layer。它是支持在 Internet 上进行安全通信的标准,并且将数据密码术集成到了协议之中。数据在离开您的计算机之前就已经被加密,然后只有到达它预定的目标后才被解密。证书和密码学算法支持了这一切的运转,使用 OpenSSL,您将有机会切身体会它们。

理论上,如果加密的数据在到达目标之前被截取或窃听,那些数据是不可能被破解的。不过,由于计算机的变化一年比一年快,而且密码翻译方法有了新的发展,因此,SSL 中使用的加密协议被破解的可能性也在增大。可以将 SSL 和安全连接用于 Internet 上任何类型的协议,不管是 HTTPPOP3,还是 FTP。还可以用 SSL 来保护 Telnet 会话。虽然可以用 SSL 保护任何连接,但是不必对每一类连接都使用 SSL。如果连接传输敏感信息,则应使用 SSL

4. 什么是openssl

OpenSSL 不仅仅是 SSL。它可以实现消息摘要、文件的加密和解密、数字证书、数字签名和随机数字。关于 OpenSSL 库的内容非常多,远不是一篇文章可以容纳的。

OpenSSL 不只是 API,它还是一个命令行工具。命令行工具可以完成与 API 同样的工作,而且更进一步,可以测试 SSL 服务器和客户机。

5. 示例程序

示例的说明请参见下面这篇周立发共享的文章。

img_e25d4fb2f8de1caf41a735ec53088516.png加密通讯协议SSL编程.pdf

6. 服务端编写步骤

7. 客户端编写步骤

8. 相关头文件

8.1. socket头文件

#include 

#include 

#include 

#include 

8.2. SSL头文件

#include 

#include 

9. 结尾

上面步骤应当画得比较清楚了,结合图再对照ssl_test.tar.gz和《加密通讯协议SSL编程.pdf》就可以非常快地上手了。

 


相关文章
|
9月前
|
IDE Shell 开发工具
python环境搭建之二 --- 运行python脚本的三种方式
python环境搭建之二 --- 运行python脚本的三种方式
110 0
|
3月前
|
Python
Python基础学习 -- 异常处理
Python基础学习 -- 异常处理
12 0
|
4月前
|
存储 Python
Python 中如何编写类型提示
Python 中如何编写类型提示
|
4月前
|
Rust C语言
rust安装 -自定义安装路径和GCC安装
rust安装 -自定义安装路径和GCC安装
99 0
|
6月前
|
存储 Linux Shell
运行 Python 脚本/代码的几种方式
运行 Python 脚本/代码的几种方式
|
6月前
|
存储 自然语言处理 Java
Python编译过程和执行原理
hello,这里是Token_w的文章,主要讲解python的基础学习,希望对大家有所帮助 整理不易,感觉还不错的可以点赞收藏评论支持,感谢!
64 0
|
程序员 编译器 Linux
G0 语言编译运行说明 | 学习笔记
快速学习 G0 语言编译运行说明
87 0
|
Linux iOS开发 Docker
Python 小技巧:如何实现操作系统兼容性打包?
Numpy 这么做是因为它是做科学计算的,为了提升效率,它把编译好的 C 拓展文件打包,从而不需要依赖环境上的 libxxx-devel 之类的库。如果你编译安装过 Python,应该有印象需要安装 zlib-devel、openssl-devel 和 libffi-devel 之类的系统依赖。但我们前面的问题比较简单,并不是有不同的编译依赖(系统级),而只是三方库依赖不同(项目级)。 另一个主要的原因,Numpy 打包出的不同系统版本,并非简简单单地用 setuptools 之类的 Python 库就能打包,而是要借助标准的镜像进行构建。
213 0
Python 小技巧:如何实现操作系统兼容性打包?
一文读懂Python对文件的各种操作方式
Python中的文件对象不仅可以用来访问普通的磁盘文件,而且也可以访问任何其它类型抽象层面上的“文件”。
|
自然语言处理 Ruby
Ruby脚本解释流程
Ruby提供了ripper这个工具,我们可利用此工具分析ruby代码,方便定位性能问题。 以下内容都是以如下代码为例: x > 100 ? 'foo' : 'bar' Ruby在执行程序前会将代码转化为更加结构化的语句 第一步:将代码切分为一个一个的词条 ripper的tokenize的方法可以将代
151 0