pyOpenSSL和WantReadError

时间:2010-03-11 19:19:26

标签: python ssl pyopenssl

我有一个套接字服务器,我试图在python 2.5上转移到SSL,但我遇到了pyOpenSSL的问题。我找不到任何关于使用它的好教程,所以我主要是在猜测。

以下是我的服务器如何设置套接字:

ctx = SSL.Context(SSL.SSLv23_METHOD)
ctx.use_privatekey_file ("mykey.pem")
ctx.use_certificate_file("mycert.pem")
sock = SSL.Connection(ctx, socket.socket(socket.AF_INET, socket.SOCK_STREAM))
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
addr = ('', int(8081))
sock.bind(addr)
sock.listen(5)

以下是接受客户的方式:

sock.setblocking(0)
while True:
  if len(select([sock], [], [], 0.25)[0]):
    client_sock, client_addr = sock.accept()
    client = ClientGen(client_sock)

以下是它从连接的套接字发送/接收的方式:

while True:
  (r, w, e) = select.select([sock], [sock], [], 0.25)

  if len(r):
    bytes = sock.recv(1024)
  if len(w):
    n_bytes = sock.send(self.message)

它是紧凑的,但你得到了一般的想法。问题是,一旦发送/接收循环开始,它会在发送或接收任何内容之前立即死亡(我无论如何都可以看到):

Traceback (most recent call last):
  File "ClientGen.py", line 50, in networkLoop
    n_bytes = sock.send(self.message
WantReadError

手册对'WantReadError'的描述非常含糊,说它几乎可以来自任何地方。我做错了什么?

1 个答案:

答案 0 :(得分:5)

有时为了发送SSL连接的应用程序字节,您需要能够首先从连接中读取更多字节。 WantReadError是指出这种情况的方式。你做错的唯一一件事就是你没有处理WantReadError,然后等到select表示套接字可读,然后再尝试调用{{1}再次。