0
私はPythonで新しくなっていますので、私と一緒にご負担ください。基本的にはソケットネットワークに関するスクリプトがあります。スクリプト:Pythonソケットネットワーキング - ValueError:list.remove(x):xがリストにありません
class TheServer:
input_list = []
channel = {}
channel_ = {}
request = {}
def __init__(self, host, port):
self.server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
self.server.bind((host, port))
self.server.listen(200)
def main_loop(self):
self.input_list.append(self.server)
while 1:
ss = select.select
inputready, outputready, exceptready = ss(self.input_list, [], [])
for self.s in inputready:
if self.s == self.server:
self.on_accept()
break
try:
self.netdata = self.s.recv(buffer_size)
except Exception, e:
self.netdata =''
if len(self.netdata) == 0:
self.on_close()
else:
if cmp(self.channel[self.s],self.channel_[self.s]):
self.on_outbounddata()
else:
self.on_execute()
def on_accept(self):
forward = Forward().start(forward_to[0], forward_to[1])
clientsock, clientaddr = self.server.accept()
if forward:
self.input_list.append(clientsock)
self.input_list.append(forward)
self.channel[clientsock] = forward
self.channel[forward] = clientsock
self.channel_[clientsock] = forward
self.channel_[forward] = forward
else:
waktu = datetime.datetime.strftime(datetime.datetime.now(), '%H:%M:%S')
with open('/www/dial.log', 'a') as file:
file.write(str(waktu) + " Proxy " + str(forward_to[0]) + ":" + str(forward_to[1]) + " isn't responding\n")
file.close()
print "Proxy " + str(forward_to[0]) + ":" + str(forward_to[1]) + " isn't responding"
print "Closing connection with client side", clientaddr
clientsock.close()
def on_close(self):
self.input_list.remove(self.s)
self.input_list.remove(self.channel[self.s])
out = self.channel[self.s]
self.channel[out].close()
self.channel_[out].close()
self.channel[self.s].close()
self.channel_[self.s].close()
del self.channel[out]
del self.channel_[out]
del self.channel[self.s]
del self.channel_[self.s]
def on_execute(self):
netdata = self.netdata
あなたはどう思いますかは、上記のスクリプトが間違っている:
Traceback (most recent call last):
File "socks", line 293, in <module>
server.main_loop()
File "socks", line 210, in main_loop
self.on_close()
File "socks", line 237, in on_close
self.input_list.remove(self.s)
ValueError: list.remove(x): x not in list
ここで私が持っているスクリプトがですか?そのエラーが発生するたびにスクリプトを手動で再起動する必要があります。
アップデート:アップデート2
Traceback (most recent call last):
File "socks", line 296, in <module>
server.main_loop()
File "socks", line 210, in main_loop
self.on_close()
File "socks", line 241, in on_close
self.input_list.remove(self.channel[self.s])
KeyError: <socket._socketobject object at 0x7f0669e93a60>
:
私はそれがエラーを解決したが、その後、私はこれを得たと思った、
def on_close(self):
try:
self.input_list.remove(self.s)
except ValueError:
print "self.s is not in the list"
self.input_list.remove(self.channel[self.s])
out = self.channel[self.s]
self.channel[out].close()
self.channel_[out].close()
self.channel[self.s].close()
self.channel_[self.s].close()
を@Mosesからの提案を試してみました 私のスクリプトをこのように変更しました
def on_close(self):
try:
self.input_list.remove(self.s)
except ValueError:
print "self.s is not in the list"
pass
self.input_list.remove(self.channel.get(self.s, None))
out = self.channel[self.s]
self.channel[out].close()
self.channel_[out].close()
self.channel[self.s].close()
self.channel_[self.s].close()
del self.channel[out]
del self.channel_[out]
del self.channel[self.s]
del self.channel_[self.s]
そして、私はまだ、このエラーが出る:
self.s is not in the list
Traceback (most recent call last):
File "socks", line 296, in <module>
try:
File "socks", line 210, in main_loop
self.on_close()
File "socks", line 241, in on_close
pass
ValueError: list.remove(x): x not in list
別のエラーが現れた使用する前に、リストに存在する場合、 – hillz
'KeyError' on' self.channel [self.s] 'はキー' self.s'が辞書に存在しないことを意味します。 'self.channel.get(self.s、None)'を実行すると、キーが見つからないときに 'None'が返されます。 –
さらに別のエラーがあります。私の投稿の最新の更新をチェックしてください – hillz