49

ソケットを使用してファイル転送用のプログラムを作成しようとしています。コードのサーバー側は正常に動作しています。ただし、クライアント側では次のエラーが発生します

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 の他の投稿でヘルプを探してみましたが、どれも役に立ちませんでした。誰か助けてくれませんか?コードの一部だけを貼り付けたので、行番号が異なる場合があります

4

1 に答える 1

39

問題は明らかに (ご想像のとおり) 接続しようとしたときにサーバー側でポート 36250 が開いていなかったことです (したがって、接続が拒否されました)。別の接続でコマンドを受信した後、サーバーがこのソケットを開くはずだったことがわかりますがSEND、明らかに「クライアント側と同期して開いていませんでした」。

主な理由は、同期がまったく行われていないことです。呼び出し:

cs.send("SEND " + FILE)
cs.close()

データを OS バッファに配置するだけです。closeおそらくデータをフラッシュしてネットワークにプッシュしますが、データがサーバーに到達する前に戻ってくることはほぼ確実です。sleep後に追加closeすると問題が軽減される可能性がありますが、これは同期ではありません

正しい解決策は、サーバーが接続を開いていることを確認することです。これには、サーバーが何らかのメッセージを返信する必要があります (たとえばOK、またはPORT 36250接続先を示すためにはより適切です)。これにより、サーバーがすでにリッスンしていることを確認できます。

もう 1 つは、バッファから取得されたバイト数を確認するために、 の戻り値を確認する必要があることです。sendまたは使用しますsendall

(この遅い回答で邪魔をして申し訳ありませんが、これはトラフィックの多い質問であることがわかり、コメントセクションの睡眠のアイデアが本当に好きではありませんでした。)

于 2014-12-01T18:03:31.287 に答える