OpenSSL使用SSL_read() 函数来读取数据,跟使用read()一样,我们只需要简单的选择一个合适大小的缓冲,然后将它传递给SS L_read()函数。注意到缓冲区的大小在此处并没有多么的重要,SSL_read() 和read()一样,返回可用的数据,哪怕它比请求的数据量小. 另外,如果没有数据可以读取,读函数将会阻塞。
如果返回值是0,并不表示没有数据可以读取,因为在没有数据可以读取的情况下,正如上面已经讨论过的一样, 我们的函数肯定会被阻塞住的。所以,此处返回的0表明这个套接字已经被关闭了,当然也就没有任何数据可以读取了,所以我们退出循环。
如果返回值是一个负值,这时肯定发生了某种错误。我们只关心两种类型的错误:普通错误和提前关闭的错误,我们使用SSL_get_error()函数来决定得到的是那 种类型的错误,差错处理在客户端的程序中非常的简单。所以对于大多数错误,我们仅仅使用berr_exit()函数来打印一行错误信息然后退出,然后,提前关闭这种错 误需要进行特殊的处理.