python 网络编程详解及简单实例

python 网络编程详解及简单实例,第1张

概述python网络编程详解网络编程的专利权应该属于Unix,各个平台(如windows、Linux等)、各门语言(C、C++、Python、Java等)所实现的符合自身特性的语法都大同小异。在我看来,懂得了Unix的socket网络编程,其他的形式

python 网络编程详解

网络编程的专利权应该属于Unix,各个平台(如windows、linux等)、各门语言(C、C++、Python、Java等)所实现的符合自身特性的语法都大同小异。在我看来,懂得了Unix的socket网络编程,其他的形式的网络编程方法也就知道了。这句话说得还不太严谨。准确的应该说成懂得了socket编程的原理,网络编程也就知道了,不同之处就在于每个平台,每个语言都有自己专享的语法,我们直接灵活套用就行了。

下面是用python实现的最基本的网络编程的例子,即依托于客户端-服务器的架构,实现客户端与服务器之间的单向“数据流通”。我们分别用两个方法来实现,一个方法是最原始的socket编程,另一个方法是利用python的面向对象对第一种方法进行封装实现,目的是减少实现透明性,便于快速开发。

要求:客户端输入数据,发送到服务端,服务器端生成(时间戳+数据)的封装数据回应客户端。由于socket编程包括两种:面向连接的和无连接的,这两种分别对应TCP数据流和UDP数据报文。所以,我们两种方法都进行实现。

一、Python socket编程

面向连接的TCP socket编程:

# -*- Coding: utf-8 -*- 3 from socket import *from time import ctime # Address and PortHOST = ''PORT = 21567ADDR = (HOST,PORT)# BuffSizeBUFSIZ = 1024# build sockettcpserSock = socket(AF_INET,SOCK_STREAM)# bind sockettcpserSock.bind(ADDR)# Listen 5 clIEnt tcpserSock.Listen(5)try:  while True:    print 'waiting for connection...'    # build clIEnt socket    tcpCliSock,addr = tcpserSock.accept()    print '...connect from:',addr    # accept data and process    while True:      data = tcpCliSock.recv(BUFSIZ)      if not data:        break      tcpCliSock.send('[%s] %s' % (ctime(),data))      # close clIEnt socket       tcpCliSock.close()except EOFError,KeyboardInterrupt:  tcpserSock.close()
# -*- Coding:utf-8 -*-from socket import *# Address and Port HOST = '127.0.0.1'PORT = 21567ADDR = (HOST,PORT)# BufferSizeBUFSIZ = 1024#build socket tcpCliSocket = socket(AF_INET,SOCK_STREAM)tcpCliSocket.connect(ADDR)while True:  data = raw_input('> ')  if not data:    break  # send data  tcpCliSocket.send(data)  # recv data  data = tcpCliSocket.recv(BUFSIZ)  if not data:    break  # show data  print datatcpCliSocket.close()

无连接的UDP socket编程

# -*- Coding: utf-8 -*-from socket import *from time import ctime # Address and Port HOST = ''PORT = 8000ADDR = (HOST,PORT)# BufferSizeBUFFSIZE = 1024# build socketudpSerSock = socket(AF_INET,SOCK_DGRAM)# bind socketudpSerSock.bind(ADDR)try:  while True:    print 'waiting the message...'    data,addr = udpSerSock.recvfrom(BUFFSIZE)    print 'received the message: '+data+' from: ',addr    udpSerSock.sendto('[%s] %s' % (ctime(),data),addr)except EOFError,KeyboardInterrupt:  udpSerSock.close()
# -*- Coding: utf-8 -*-from socket import *# Address and Port HOST = 'localhost'PORT = 8000ADDR = (HOST,PORT)# BufferSizeBUFSIZ = 1024# build socket udpCliSock = socket(AF_INET,SOCK_DGRAM)while True:  data = raw_input('> ')  udpCliSock.sendto(data,ADDR)  data = udpCliSock.recvfrom(BUFSIZ)  if not data:    break  print data udpCliSock.close()

二、基于封装类SocketServer的网络编程

# -*- Coding: utf-8 -*-from SocketServer import Tcpserver as TCP,StreamRequestHandler as SRH from time import ctime # Address and PortHOST = ''PORT = 21567ADDR = (HOST,PORT)# BuffSizeBUFSIZ = 1024# build RequestHandlerclass MyRequestHandler(SRH):  def handle(self):    print '...connected from: ',self.clIEnt_address    self.wfile.write('[%s] %s' % (ctime(),self.rfile.readline()))# build TcpserverTcpserv = TCP(ADDR,MyRequestHandler)print 'waiting for connection...'# loop to processTcpserv.serve_forever()
# -*- Coding:utf-8 -*-from socket import *# Address and Port HOST = '127.0.0.1'PORT = 21567ADDR = (HOST,PORT)# BufferSizeBUFSIZ = 1024while True:  # note: SocketServer 的请求处理器的默认行为是接受连接,  # 得到请求,然后就关闭连接,所以需要多次连接  tcpCliSock = socket(AF_INET,SOCK_STREAM)  tcpCliSock.connect(ADDR)  # process data  data = raw_input('> ')  if not data:    break  tcpCliSock.send('%s\r\n' % data)  data = tcpCliSock.recv(BUFSIZ)  if not data:    break  print data.strip()  tcpCliSock.close()

感谢阅读,希望能帮助大家,谢谢大家对本站的支持!

总结

以上是内存溢出为你收集整理的python 网络编程详解及简单实例全部内容,希望文章能够帮你解决python 网络编程详解及简单实例所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1202254.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存