openssl之BIO系列之9---BIO对的创建和应用
BIO对的创建和应用
---依据openssl doc/crypto/bio/bio_new_bio_pair.pod翻译和自己的理解写成
(作者:DragonKing Mail:wzhah@263.net 公布于:http://gdwzh.126.com之open
ssl专业论坛)
BIO对是BIO中专门创建的一对缓存BIO。要创建BIO对。调用以下定义的函数(open
ssl\bio.h):
int BIO_new_bio_pair(BIO **bio1, size_t writebuf1, BIO **bio2, size_t wr
itebuf2);
这个函数调用成功后返回1,这时候bio1和bio2都是有效的了。否则就返回0。而bi
o1和bio2就会设为NULL,这是后能够检測出错堆栈以得到很多其它错误信息。
这个BIO对创建之后,它的两端都能作为数据缓冲的输入和输出。
典型的应用是它一
端和SSL的IO连接,而还有一端则被应用控制,这样,应用程序就不须要直接和网络连接打
交道了。
这两个BIO对的功能是全然对称的,它们的缓冲区的大小由參数writebuf1和writeb
uf2决定,假设给定的大小是0,那么该函数就会使用缺省的缓存大小。BIO_new_bio_pa
ir不会检查bio1和bio2是否真的指向其他BIO,bio1和bio2的值都被重写,可是在此之前
不会调用BIO_free()函数。所以。在使用bio1和bio2之前,必须自己保证这两个变量是
空的BIO,否则可能造成内存泄漏。
值得注意的是,尽管这两个BIO是一对的和一起创建的,可是却必须分别释放。之所
以这样做,是有其重要原因的,由于有些SSL函数,如SSL_set_bio或BIO_free会隐含调
用BIO_free函数,所以这时候还有一端的BIO就仅仅能单独释放了。
为了让大家对BIO对的应用模型有一个感性的认识,以下举一个简单的样例说明问题
。
BIO对能给提供应用程序中对网络处理的全然控制能力,程序能够对依据须要调用s
oket的select()函数,同一时候却能够避免直接处理SSL接口。以下是使用BIO_new_bio_pai
r的简单代码模型:
BIO *internal_bio, *network_bio;
...
BIO_new_bio_pair(internal_bio, 0, network_bio, 0);
SSL_set_bio(ssl, internal_bio);
SSL_operations();
...
application | TLS-engine
| |
+----------> SSL_operations()
| /\ ||
| || \/
| BIO-pair (internal_bio)
+----------< BIO-pair (network_bio)
| |
socket |
...
SSL_free(ssl); /* 隐式释放 internal_bio */
BIO_free(network_bio); /* 显式释放 network_bio*/
...
由于BIO对仅仅会简单的缓存数据,而不会直接涉及到连接。所以它看起来就想非堵塞
型的接口,假设写缓存满了或读缓存空的时候,调用IO函数就会立马返回。也就是说,
应用程序必须自己对写缓存运行flush操作或对读缓存运行fill操作。能够使用前面介绍
过的BIO_ctrl_pending函数看看是否有数据在缓存里面并须要传输到网络上去;为了下
面的SSL_operation可以正确运行。可以调用BIO_ctrl_get_read_request函数,以决定
须要在写缓存写入多少数据。
上面两个函数能够保证正确的SSL操作的进行。
须要注意的是,SSL_operation的调用可能会出现返回ERROR_SSL_WANT_READ值。但
这时候写缓存却还有数据的情况,所以应用程序不能简单的依据这个错误代码进行推断
。而必须保证写缓存以及运行过flush操作了,否则就会造成死锁现象,由于还有一端可能
知道等到有数据了才会继续进行以下的操作。
openssl之BIO系列之9---BIO对的创建和应用的更多相关文章
- openssl之BIO系列之18---接受(accept)类型BIO
接受(accept)类型BIO ---依据openssl doc\crypto\bio_s_accept.pod翻译和自己的理解写成 (作者:DragonKing, Mail: wzhah@263.n ...
- openssl之BIO系列之22---Cipher类型的BIO
Cipher类型BIO ---依据openssl doc\crypto\bio_f_cipher.pod翻译和自己的理解写成 (作者:DragonKing, Mail: wzhah@263.net , ...
- openssl之BIO系列之20---缓冲(buffer)类型BIO
缓冲(buffer)类型BIO ---依据openssl doc\crypto\bio_f_buffer.pod翻译和自己的理解写成 (作者:DragonKing, Mail: wzhah@263.n ...
- openssl之BIO系列之24---SSL类型的BIO
SSL类型的BIO ---依据openssl doc\crypto\bio_f_ssl.pod翻译和自己的理解写成 (作者:DragonKing, Mail: wzhah@263.net ,公布于:h ...
- OpenSSL之X509系列
OpenSSL之X509系列之1---引言和X509概述 [引言] X509是系列的函数在我们开发与PKI相关的应用的时候我们都会用到,但是OpenSSL中对X509的描述并不是很多,鉴于些,我 ...
- openssl之EVP系列之1---算法封装
openssl之EVP系列之1---算法封装 ---依据openssl doc/crypto/EVP.pod翻译和自己的理解写成 (作者:DragonKing, Mail: wzhah ...
- openssl之EVP系列之13---EVP_Open系列函数介绍
openssl之EVP系列之13---EVP_Open系列函数介绍 ---依据openssl doc/crypto/EVP_OpenInit.pod翻译和自己的理解写成 (作者:Dra ...
- openssl之EVP系列之9---EVP_Digest系列函数的一个样例
openssl之EVP系列之9---EVP_Digest系列函数的一个样例 ---依据openssl doc/crypto/EVP_DigestInit.pod翻译 (作者:Drago ...
- openssl之EVP系列之8---EVP_Digest系列函数具体解释
openssl之EVP系列之8---EVP_Digest系列函数具体解释 ---依据openssl doc/crypto/EVP_DigestInit.pod翻译和自己的理解写成 (作 ...
随机推荐
- JAVA使用JDBC连接MySQL数据库 一
public class JDBCTest { public static void main(String[] args){ String driver = "com.mysql.jdbc ...
- pat 团体天梯赛 L2-006. 树的遍历
L2-006. 树的遍历 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历 ...
- rsync Linux系统下的数据镜像备份工具
rsync是Linux系统下的数据镜像备份工具,从软件的命名上就可以看出来了——remote sync.rsync支持大多数的类Unix系统,无论是Linux.Solaris还是BSD上都经过了良好的 ...
- POJ 2635 The Embarrassed Cryptographer (千进制,素数筛,同余定理)
The Embarrassed Cryptographer Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 15767 A ...
- 十步完全理解 SQL(转载)
1 SQL是一种声明式语言 SQL 语言是为计算机声明了一个你想从原始数据中获得什么样的结果的一个范例,而不是告诉计算机如何能够得到结果.学好SQL要改变传统函数式编程思想,例如用变量传参.使用循环语 ...
- linux 共享内存 信号量 同步
这篇文章将讲述别一种进程间通信的机制——信号量.注意请不要把它与之前所说的信号混淆起来,信号与信号量是不同的两种事物.有关信号的更多内容,可以阅读我的另一篇文章:Linux进程间通信——使用信号.下面 ...
- The C programming language [book]
1 A12.3 Macro Definition and Expansion A control line of the form #define identifier token-sequence ...
- 通过vSphere-client虚拟化服务器
一.什么是vClientvClient是vSphere的重要组件之一.用于用户连接ESXi或vCenter管理和分配vSphere的各种资源.有vClient和WebvClient两个版本.安装部署了 ...
- Codeforces 716C. Plus and Square Root-推公式的数学题
http://codeforces.com/problemset/problem/716/C codeforces716C. Plus and Square Root 这个题就是推,会推出来规律,发现 ...
- C++ primer分章节快速回顾
第三章: 1,sozeof(int): int n_int=INT_MAX; sizeof n_int;(对变量括号可选) 2,#include<climits>包含一些类型的最大值3,c ...