SSL_read 返回值为0困惑

SSL_read的原型是:
int SSL_read(SSL *ssl, void *buf, int num);
open ssl的文档这样说:
SSL_read是工作在SSL/TLS的记录之上的。数据按照记录来接收的(最大记住是16KB SSLv3/TLS)。只有在一个记录被完整接收之后才会被处理(解密和验证)。因此SSL_read只会在记录数据都读取成功了才能返回数据,否则SSL_read只会触发读取下一个记录组。如果num的数量比缓冲的数据量大,那么SSL_read会返回缓冲区的内容;如果缓冲区没有内容,那么触发读取下个记录。SSL_read最多返回的就是一个记录的长度。由于SSL/TLS记录的大小可能超过底层TCP包的大小,所以有可能需要让SSL读取多个TCP包,SSL_read才能成功。

从这段介绍来看,SSL_read可能返回失败或者1到记录大小。那么一个记录到底实际有多大?

从我的测试来看,我调用返回从来没有超过1024字节;难道OpenSSL为了性能改进尽量保证每个SSL_read能成功,自动将SSL记录设置成小于TCP分组的大小?

另外测试当中还发现以下两种情况:
1.当返回值小于1024的时候,SSL_errno等于0,errno也等于0
2.当传递的num等于0的时候,SSL_errno等于5,但这个时候不是表明连接被关闭了。


通过自己的测试发现当数据小于1024字节时,SSL_read返回值为0……

引用:http://www.cppblog.com/windcsn/archive/2012/01/05/163631.html

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值