1

ssl を使用してサーバーをコーディングしようとしていますが、理解できないエラーがあります。コードは次のとおりです。

import socket, ssl, select, sys, exceptions

def do_something(connstream, data):
if not data:
    return False
connstream.write(data)
print data
return True

def deal_with_client(connstream):
data = connstream.read()
# null data means the client is finished with us
while data:
    if not do_something(connstream, data):
        # we'll assume do_something returns False
        # when we're finished with client
        break
    data = connstream.read()
# finished with client

bindsocket = socket.socket()
bindsocket.bind(('127.0.0.1', 240))
bindsocket.listen(5)



while True:
newsocket, fromaddr = bindsocket.accept()
try:
    connstream = ssl.wrap_socket(newsocket, server_side=True, certfile="E:\oromenetwork\test\cert", keyfile="E:\oromenetwork\test\key", ca_certs=None, ssl_version=ssl.PROTOCOL_TLSv1)
    connstream.write("Bonjour")
    deal_with_client(connstream)
except ssl.SSLError as e:
    print "warp error "
    print e
    newsocket.shutdown(socket.SHUT_RDWR)
    newsocket.close()
    exit()
except exceptions.TypeError as e:
    print "other error"
    #print "Unexpected error:", sys.exc_info()[0]
    print e
    newsocket.shutdown(socket.SHUT_RDWR)
    newsocket.close()
    exit()

だから私は openssl s_client -connect 127.0.0.1:240 でそれをテストします

そして、ここにエラーがあります: [Errno 336265218] _ssl.c:351 error:140B0002:SSL routines:SSL_CTX_use_PrivateKey_file:system lib

私はすでに許可とパスを確認しました

4

1 に答える 1

4

certfile と keyfile への文字列"\t",では、Tab のエイリアスである which を使用します。"\\"バックスラッシュを ( として)エスケープするか、 を使用するos.path.joinか、生の文字列を使用します。

connstream = ssl.wrap_socket(newsocket, server_side=True,
                             certfile=r"E:\oromenetwork\test\cert",
                             #       v^
                             keyfile=r"E:\oromenetwork\test\key",
                             ca_certs=None,ssl_version=ssl.PROTOCOL_TLSv1)
于 2013-02-12T16:20:15.677 に答える