python网络基础编程笔记(一)

感觉上python 和c,c++对网络的处理流程上是一样的。记录如下供以后参考
import socket, traceback, os, sys, select

class stateclass:
	stdmask = select.POLLERR | select.POLLHUP | select.POLLNVAL
	
	def __init__(self, mastersock):
		self.p = select.poll()
		self.mastersock = mastersock
		self.watchread(mastersock)
		self.readbuffers = {}
		self.writebuffers = {}
		self.sockets = {mastersock.fileno():mastersock}
	def fd2socket(self, fd):
		return self.sockets[fd]
	def watchread(self, fd):
		self.p.register(fd, select.POLLIN | self.stdmask)
	def watchwrite(self, fd):
		self.p.register(fd, select.POLLOUT | self.stdmask)
	def watchboth(self, fd):
		self.p.register(fd, select.POLLIN | select.POLLOUT | self.stdmask)
	def dontwatch(self, fd):
		self.p.unregister(fd)
	def sendtoall(self, text, originfd):
		for line in text.split("\n"):
			line = line.strip()
			transmittext = str(self.fd2socket(originfd).getpeername()) + \
			": " + line + "\n"
			for fd in self.writebuffers.keys():
				self.writebuffers[fd] += transmittext
				self.watchboth(fd)
				
	def newconn(self, sock):
		fd = sock.fileno()
		self.watchboth(fd)
		self.writebuffers[fd] = "Welcome to the chat server, %s\n" % \
		str(sock.getpeername())
		self.readbuffers[fd] = ""
		self.sockets[fd] = sock
	def readevent(self, fd):
		try:
			self.readbuffers[fd] += self.fd2socket(fd).recv(4096)
		except:
			self.closeout(fd)
		parts = self.readbuffers[fd].split("SEND")
		if len(parts) < 2:
			return
		elif parts[-1] == '':
			self.readbuffers[fd] = ""
			sendlist = parts[:-1]
		else:
			self.readbuffers[fd] = parts[-1]
			sendlist = parts[:-1]

		for item in sendlist:
			self.sendtoall(item.strip(), fd)
	def writeevent(self, fd):
		if not len(self.writebuffers[fd]):
			self.watchread(fd)
			return
		try:
			byteswritten = self.fd2socket(fd).send(self.writebuffers[fd])
		except:
			self.closeout(fd)
		self.writebuffers[fd] = self.writebuffers[fd][byteswritten:]
		if not len(self.writebuffers[fd]):
			self.watchread(fd)
	def errorevent(self, fd):
		self.closeout(fd)
	def closeout(self, fd):
		self.dontwatch(fd)
		try:
			self.fd2socket(fd).close()
		except:
			pass
		del self.writebuffers[fd]
		del self.sockets[fd]
	def loop(self):
		while 1:
			result = self.p.poll()
			for fd, event in result:
				if fd == self.mastersock.fileno() and event == select.POLLIN:
					try:
						newsock, addr = self.fd2socket(fd).accept()
						newsock.setblocking(0)
						print "Got connection from ", newsock.getpeername()
						self.newconn(newsock)
					except:
						pass
				elif event == select.POLLIN:
					self.readevent(fd)
				elif event == select.POLLOUT:
					self.writeevent(fd)
				else:
					self.errorevent(fd)

host = ''
port = 51423
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
s.bind((host, port))
s.listen(1)
s.setblocking(0)

state = stateclass(s)
state.loop()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前进的蜗牛啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值