书上用c写的,还要在linux下运行。在网上找了下python写socket (链接).You cannot but admit python is just so beautiful!
原链接的代码有点问题,没有实现持续的监听。稍微改了一下,就可以在命令行下,像qq那样即时文字聊天了
server.py
#!/usr/bin/python
# -*- coding: utf-8 -*-
import socket
from time import ctime
'''
host为空表示bind可以绑定到所有有效地址上
port 必须要大于1024
bufsiz为缓冲区 我们设置为1K
'''
host = ''
port = 23456
bufsiz = 1024
ADDR = (host,port)
tcpSerSock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcpSerSock.bind(ADDR)
tcpSerSock.listen(5) #参数表示允许多少连接同时连进来
try:
while True:
'''
进入服务器的无限循环中,等待连接到来
有链接时,进入对话循环,等待客户发送数据,如果消息为空,表示客户端已经退出,等待下一个客户端连接
得到客户端消息后在消息前加一个时间戳后返回
'''
print 'waiting for connection...'
new_s,addr = tcpSerSock.accept()
print '...connected from ',addr
while True:
data = new_s.recv(bufsiz)
if not data:
new_s.close()
break
print data
data = raw_input('> ')
new_s.send('[%s] %s' %(ctime(),data))
except BaseException, e:
tcpSerSock.close() #记住在服务器退出时记得关闭
client.py
import socket
host = '127.0.0.1'
port = 23456
bufsiz = 1024
ADDR = (host,port) #目标地址和端口
tcpCliSock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
while True:
try:
tcpCliSock.connect(ADDR)
break
except:
print 'error please waiting..'
while True:
data = raw_input('> ')
if not data:
break
tcpCliSock.send(data)
data = tcpCliSock.recv(bufsiz)
if not data:
break
print data
tcpCliSock.close()