ソケットを使用してファイル転送用のプログラムを作成しようとしています。サーバー側のコードは正常に動作しています。ただし、クライアント側で次のエラーが表示されます
Traceback (most recent call last):
File "client.py", line 54, in <module>
uploadFiles(directory)
File "client.py", line 36, in uploadFiles
transferFile(fname)
File "client.py", line 13, in transferFile
cs.connect((Host, 36258))
File "/usr/lib/python2.7/socket.py", line 224, in meth
return getattr(self._sock,name)(*args)
socket.error: [Errno 111] Connection refused
私のコードは次のとおりです
import os
import socket
def transferFile(fname):
Host = '127.0.0.1'
CPORT = 36258
MPORT = 36250
FILE = fname
cs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
cs.connect((Host, 36258))
cs.send("SEND " + FILE)
cs.close()
ms = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
ms.connect((Host, MPORT))
f = open(FILE, "rb")
data = f.read()
f.close()
ms.send(data)
ms.close()
def uploadFiles(directory):
home = os.getenv("HOME")
folder = str(home + "/" + directory)
os.chdir(folder)
dirList = os.listdir(folder)
print dirList
for fname in dirList:
if fname.endswith('.bin'):
transferFile(fname)
os.chdir(os.getenv("HOME"))
directory = "testdownload"
if not os.path.exists(directory):
os.makedirs(directory)
os.chdir(directory)
uploadFiles(directory)
GoogleやStack Overflowの他の投稿で助けを探してみましたが、誰も助けませんでした。誰か助けてくれますか?コードの一部のみを貼り付けたため、行番号が異なる場合があります
問題は、(あなたが考え出したように)接続しようとしたときにサーバー側でポート36250が開いていなかったことです(したがって、接続は拒否されました)。別の接続でSEND
コマンドを受信した後、サーバーがこのソケットを開くはずだったのを見ることができますが、どうやら「クライアント側と同期して[開かない]」ようでした。
まあ、主な理由は、同期がまったくなかったことでしょう。呼び出し:
cs.send("SEND " + FILE)
cs.close()
oSバッファーにデータを配置するだけです。 close
はおそらくデータをフラッシュしてネットワークにプッシュしますが、データがサーバーに到達する前にほぼ確実に戻ります。 sleep
の後にclose
を追加すると、問題を軽減できる場合がありますが、これは同期ではありません。
正しい解決策は、確認サーバーが接続を開いたことです。これには、サーバーが何らかのメッセージを送り返す必要があります(たとえば、OK
、またはそれ以上のPORT 36250
は接続先を示します)。これにより、サーバーが既にリッスンしていることが確認されます。
もう1つはsend
の戻り値をチェックして、バッファーから何バイトが取り出されたかを確認する必要があります。または sendall
を使用します。
(この遅い回答で邪魔してすみませんが、これは交通量の多い質問であることがわかり、コメントセクションの睡眠のアイデアは本当に好きではありませんでした。)