<p>我假设您遇到的问题如下,您正在使用PyOpenSSL打开一个连接,并且总是会得到一个WantReadError异常。你无法区分这个错误和超时。请考虑以下示例:</p>
<pre><code>#!/usr/bin/python
import OpenSSL
import socket
import struct
context = OpenSSL.SSL.Context(OpenSSL.SSL.TLSv1_METHOD)
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.settimeout(5)
connection = OpenSSL.SSL.Connection(context,s)
connection.connect(("www.gmail.com",443))
# Put the socket in blocking mode
connection.setblocking(1)
# Set the timeout using the setsockopt
tv = struct.pack('ii', int(6), int(0))
connection.setsockopt(socket.SOL_SOCKET, socket.SO_RCVTIMEO, tv)
print "Connected to " , connection.getpeername()
print "Sate " , connection.state_string()
while True:
try:
connection.do_handshake()
break
except OpenSSL.SSL.WantReadError:
print "Exception"
pass
print "Sate " , connection.state_string()
print connection.send("koekoek\r\n")
while True:
try:
recvstr = connection.recv(1024)
break
except OpenSSL.SSL.WantReadError:
print "Exception"
pass
print recvstr
</code></pre>
<p>这将打开到gmail的SSL连接,发送一个无效字符串,读取响应并打印它。注意:
*连接明确地设置为阻塞模式
*在这种情况下,recv超时被明确设置为6秒。</p>
<p>现在的行为是什么,当超时发生时,WantReadError异常将是thornw,在本例中是在等待6秒之后。(您可以删除while True以避免重试,但在本例中,我添加了它们以进行测试)。套接字上设置的超时仅在connect()调用中有效。</p>
<p>另一种选择是,当套接字保持非阻塞模式时(这可能也适用于GNUTLS情况),您可以自己执行计时,您可以在启动调用时获得时间,在while True中,尝试:除了WantReadError之外,您可以每次自己执行检查,以查看您是否等待了太长时间。</p>