Python 3.4套接字没有收到完整的消息

时间:2014-05-27 14:21:02

标签: python sockets python-3.x irc twitch

我正在编写一个机器人来监控IRC上twitch.tv上的聊天。以下是Telnet中成功连接和登录的内容:

Microsoft Telnet> o irc.twitch.tv 6667
PASS <password>
NICK <username>
:tmi.twitch.tv 001 <user> :Welcome, GLHF!
:tmi.twitch.tv 002 <user> :Your host is tmi.twitch.tv
:tmi.twitch.tv 003 <user> :This server is rather new
:tmi.twitch.tv 004 <user> :-
:tmi.twitch.tv 375 <user> :-
:tmi.twitch.tv 372 <user> :You are in a maze of twisty passages, all alike.
:tmi.twitch.tv 376 <user> :>

我写了一个简单的测试脚本,它成功连接到服务器但只接收部分消息。

# irctest.py
import socket

HOST='irc.twitch.tv'
PORT=6667

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((HOST, PORT))
s.sendall(b"PASS oauth:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\r\n")
s.sendall(b"NICK user\r\n")
data = s.recv(2048)
s.close()
print(repr(data.decode()))

使用data.decode()打印的字符串只是成功连接响应的第一行:

':tmi.twitch.tv 001 <user> :Welcome, GLHF!\r\n'

这意味着连接按预期工作。我已经尝试过第二次s.recv(2048),但这会与s.settimeout(None)无限期挂起。我也试过增加缓冲区大小,但这似乎没有任何影响。有谁知道发生了什么事?

Twitch有一个关于IRC连接的帮助文档here

1 个答案:

答案 0 :(得分:0)

我认为你应该做的是这样的事情:

import socket

HOST='irc.twitch.tv'
PORT=6667

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.settimeout(None)
s.connect((HOST, PORT))
s.sendall(b"PASS oauth:...")
s.sendall(b"USER ...")
s.sendall(b"NICK ...")
s.sendall(b"JOIN ...")

while True:
    data = irc.recv(1204)
    if data.find('PING') != -1:
        irc.send(data.replace('PING', 'PONG'))
    print(repr(data.decode()))

来自这个问题的代码: IRC bot in python won't send messages