openssl之BIO系列之15---内存(mem)类型BIO

17 篇文章 0 订阅
    内存(mem)类型BIO所定义的相关系列函数如下(openssl/bio.h):
     BIO_METHOD * BIO_s_mem(void);
    
     BIO_set_mem_eof_return(BIO *b,int v)
     long BIO_get_mem_data(BIO *b, char **pp)
     BIO_set_mem_buf(BIO *b,BUF_MEM *bm,int c)
     BIO_get_mem_ptr(BIO *b,BUF_MEM **pp)
    
     BIO *BIO_new_mem_buf(void *buf, int len);
    内存型BIO是source/sink型BIO,它使用内存作为它的I/O。写进该类型BIO的数据被存储在BUF_MEM结构中,该结构被定义为适合存储数据的一种结构,其结构定义如下:
    typedef struct buf_mem_st
    {
          int length; /* current number of bytes */
          char *data; 
          int max; /* size of buffer */ 
    } BUF_MEM;
    可见,该结构定义了内存数据长度,数据存储空间以及最大长度三个变量来表述一段内存存储数据。但值得注意的是,内存型BIO的内存是可以无限扩大的,也就是说,不过你往里面写多少数据,都能成功执行。
    一般来说,任何写入内存型BIO的数据都能被读出,除非该内存型BIO是只读类型的,那么,这时候如果对只读的内存型BIO执行读操作,那么相关数据就会从该BIO删除掉(其实没有删掉,只是指针往后面移动,访问不了了,如果调用BIO_reset就可以再访问)。
    【BIO_s_mem】
    该函数返回一个内存型的BIO_METHOD结构,期定义如下:
    static BIO_METHOD mem_method=
    {
          BIO_TYPE_MEM,
          "memory buffer",
          mem_write,
          mem_read,
          mem_puts,
          mem_gets,
          mem_ctrl,
          mem_new,
          mem_free,
          NULL,
    };
    BIO_write和BIO_read函数是支持的。对内存型BIO执行写操作总是成功的,因为内存型BIO的内存能够无限扩大。任何一个对可读写的内存型BIO的读操作都会在使用内部拷贝操作从BIO里面删除该段数据,这样一来,如果BIO里面有大量的数据,而读的却只是很小的一些片断,那么会导致操作非常慢。使用只读的内存型BIO避免了这个问题。在使用的时候,如果内存型BIO必须使用可读写的,那么可以加一个Buffer型BIO到BIO链中,这可以使操作速度更快。在以后的版本(该文档所述版本为0.9.6a),可能会优化速度操作的问题。
    BIO_gets和BIO_puts操作在该类型BIO是支持的。
    如果设置了BIO_CLOSE标志,那么内存型BIO被释放的时候其底层的BUF_MEM型BIO也同时被释放。
    BIO_reset函数被调用时,如果该BIO是可读写的,那么该BIO所有数据都会被清空;如果该BIO是只读的,那么该操作只会简单将指针指向原始位置,里面的数据可以再读。该文档所述版本的(0.9.6a)的内存型BIO对读写模式的BIO没有提供一个可以将指针重置但不破坏原有数据的方法,在以后的版本可能会增加的。
    BIO_eof返回true,表明只时候BIO里面没有可读数据。
    BIO_ctrl_pending返回目前BIO里面存储的数据的字节(byte)数。
    【BIO_set_mem_eof_return】
    该函数设置一个没有数据的内存型BIO的执行读动作的行为。如果参数v是0,那么该空的内存型BIO就会返回EOF,也就是说,这时候返回为0,如果调用BIO_should_retry就会返回false。如果参数v为非零,那么就会返回v,并且同时会设置重试标志,也就是说此时调用BIO_read_retry会返回true。为了跟正常的返回正值避免混淆,v应该设置为负值,典型来说是-1。
    【BIO_get_mem_data】
    该函数是一个宏定义函数,它将参数pp的指针指向内存型BIO的数据开始处,返回所有有效的数据。
    【BIO_set_mem_buf】
    该函数将参数bm所代表的BUF_MEM结构作为该BIO的底层结构,并把关闭标志设置为参数c,c可以是BIO_CLOSE或BIO_NOCLOSE,该函数也是一个宏定义。
    【BIO_get_mem_ptr】
    该函数也是一个宏定义函数,它将底层的BUF_MEM结构放在指针pp中。
    【BIO_new_mem_buf】
    该函数创建一个内存型BIO,其数据为buf里面长度为len的数据(单位为byte),如果参数len是-1,那么就默认buf是以null结束的,使用strlen解决长度。这时候BIO被设置为只读的,不能执行写操作。它用于数据需要存储在一块静态内存中并以BIO形式存在的时候。所需要的数据是直接从内存中读取的,而不是先要执行拷贝操作(读写方式的内存BIO就是要先拷贝),这也就要求这块内存是只读的,不能改变,一直维持到BIO被释放。
    
    【例子】
    1.创建一个内存型BIO并写入数据
    
     BIO *mem = BIO_new(BIO_s_mem());
     BIO_puts(mem, "Hello World/n"); 
    2.创建一个只读的内存型BIO
    
     char data[] = "Hello World";
     BIO *mem;
     mem = BIO_new_mem_buf(data, -1);
    
    3.把一个BUF_MEM结构从一个BIO中取出并释放该BIO
    
     BUF_MEM *bptr;
     BIO_get_mem_ptr(mem, &bptr);
     BIO_set_close(mem, BIO_NOCLOSE); /* BIO_free() 不释放BUF_MEM结构 */

     BIO_free(mem);


FW : http://blog.csdn.net/gdwzh/article/details/19215

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用OpenSSL进行数据的BIOBIOOpenSSL库中的一种抽象I/O对象)操作可以在内存缓冲区和其他数据源之间进行数据的读写。下面是一个示例代码,展示了如何使用OpenSSLBIO接口将数据从一个BIO对象读取到另一个BIO对象中: ```c #include <stdio.h> #include <string.h> #include <openssl/bio.h> int main() { // 创建两个内存BIO对象 BIO *bio_src = BIO_new(BIO_s_mem()); BIO *bio_dest = BIO_new(BIO_s_mem()); // 将数据写入源BIO对象 const char *data = "Hello, OpenSSL!"; BIO_write(bio_src, data, strlen(data)); // 从源BIO对象读取数据到目标BIO对象 char buffer[256]; int len; while ((len = BIO_read(bio_src, buffer, sizeof(buffer))) > 0) { BIO_write(bio_dest, buffer, len); } // 从目标BIO对象中读取数据并打印 char *dest_data; len = BIO_get_mem_data(bio_dest, &dest_data); printf("Data in destination BIO: %.*s\n", len, dest_data); // 释放内存和资源 BIO_free_all(bio_src); BIO_free_all(bio_dest); return 0; } ``` 在这个示例中,我们创建了一个源BIO对象 `bio_src` 和一个目标BIO对象 `bio_dest`。然后,我们使用 `BIO_write` 将数据写入源BIO对象。接下来,我们使用 `BIO_read` 从源BIO对象读取数据,并使用 `BIO_write` 将数据写入目标BIO对象。最后,我们使用 `BIO_get_mem_data` 获取目标BIO对象中的数据,并打印出来。 请注意,这只是一个简单的示例,实际使用中可能会涉及更多的错误处理和其他操作。你可以根据自己的需求进行适当的修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值