openssl之BIO系列之13---Socket类型BIO

来源:互联网 发布:大屏幕播放软件 编辑:程序博客网 时间:2024/04/29 05:33
Socket类型的BIO也是一种source/sink型BIO,封装了Socket的IO操作,它相关的一些函数定义如下(openssl/bio.h):
     BIO_METHOD * BIO_s_socket(void);
     #define BIO_set_fd(b,fd,c) BIO_int_ctrl(b,BIO_C_SET_FD,c,fd)
     #define BIO_get_fd(b,c) BIO_ctrl(b,BIO_C_GET_FD,0,(char *)c)
     BIO *BIO_new_socket(int sock, int close_flag);
    前面我们在介绍fd类型BIO的时候曾经说过,它的函数的实现文件跟Soket类型的BIO其实是放在一起的,都在文件bss_socket.c里面,从这些定义我们就可以知道,之所以这样做,是因为这两种类型的BIO实现的函数基本是相同的,并且具有很多的共性。
    【BIO_s_socket】
    该函数返回一个Socket类型的BIO_METHOD结构,BIO_METHOD结构的定义如下:
    static BIO_METHOD methods_sockp=
     {
          BIO_TYPE_SOCKET,
          "socket",
          sock_write,
          sock_read,
          sock_puts,
          NULL, /* sock_gets, */
          sock_ctrl,
          sock_new,
          sock_free,
          NULL,
     };
    可以看到,它跟fd类型BIO在实现的动作上基本上是一样的。只不过是前缀名和类型字段的名称不一样。其实在象Linux这样的系统里,Socket类型跟fd类型是一样,他们是可以通用的,但是,为什么要分开来实现呢,那是因为有些系统如windows系统,socket跟文件描述符是不一样的,所以,为了平台的兼容性,openssl就将这两类分开来了。
    BIO_read和BIO_write对底层的Socket结构进行读写操作。
    BIO_puts是支持的,但是BIO_gets在Socket类型BIO中是不支持的,大家如果看源代码就可以知道,虽然BIO_gets在Socket类型是不支持的,但是如果调用该函数,不会出现异常,只会返回-1的出错信息。
    如果设置了关闭标志,那么当BIO被释放的时候底层的Socket连接就会被关闭。
    【BIO_set_fd】
    该函数将Socket描述符fd设置为BIO的底层IO结构,同时可以设置关闭标志c。该函数返回1。
    【BIO_get_fd】
    该函数返回指定BIO的Socket描述符,如果c参数不是NULL,那么就将该描述符存在参数c里面,当然,Socket描述符同时也作为返回值,如果BIO没有初始化则调用失败,返回-1。
    【BIO_new_socket】

    该函数根据给定的参数返回一个socket类型的BIO,成功返回该BIO指针,失败返回NULL。其实,该函数依次调用了BIO_s_socket,BIO_new和BIO_set_fd实现它的功能。


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

0 0
原创粉丝点击