クライアントが暗号AES-256暗号化を使用して暗号化されたJSONデータを送信し、受信したファイルの解読と処理を担当するソケットを使用してクライアントサーバーアプリケーションを開発しています。AES解読が機能しない
私はローカルホスト上で暗号化を試みましたが、CentOS Serverを設定しても動作しませんでした。クライアントからの暗号化データは受信されますが、復号化されません。ここ
は、サーバーのコードです:
Serverコード
#!/usr/bin/python
import socket
import threading
import Encryption
class ThreadedServer(object):
def __init__(self, host, port):
self.host = host
self.port = port
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
self.sock.bind((self.host, self.port))
def listen(self):
self.sock.listen(5)
while True:
client, address = self.sock.accept()
client.settimeout(60)
threading.Thread(target = self.listenToClient,args = (client,address)).start()
def listenToClient(self, client, address):
size = 4096
while True:
print("Receiving")
try:
data = client.recv(size)
if data:
cipher = Encryption.Encryption('mysecretpassword')
jsondata = cipher.decrypt(data)
print(jsondata)
self.request.close()
else:
raise socket.error('Client disconnected')
except:
client.close()
return False
if __name__ == "__main__":
ThreadedServer(adress,port).listen()
と暗号化ファイルがhere
データサイズが、その場合にはデータが右切り捨てられる> 4096である場合、私は見ている問題があることでしょうか? –
@ Jean-François私はローカルホストでこれを試しましたが、データサイズには関係ないのでうまく動作しました。 – sw1
それにもかかわらず、 'data = client.recv(size)' *という行は、メッセージ境界がパケット境界に対応すると誤って想定しています。それは時々起こるかもしれませんが、それに頼ることはできません。信頼できる方法を使用して、各ネットワークメッセージの先頭に4バイトのビッグエンディアン長の値を付けるなど、メッセージの終了をサーバーが判断できるようにする必要があります。 –