python网络编程初级

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

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

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

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

一、Python socket编程

面向连接的TCP socket编程:

 1 # -*- coding: utf-8 -*-
 2
 3 from socket import *
 4 from time import ctime 
 5 
 6 # Address and Port
 7 HOST = ''
 8 PORT = 21567
 9 ADDR = (HOST, PORT)
10 
11 # BuffSize
12 BUFSIZ = 1024
13 
14 # build socket
15 tcpSerSock = socket(AF_INET, SOCK_STREAM)
16 # bind socket
17 tcpSerSock.bind(ADDR)
18 # listen 5 client 
19 tcpSerSock.listen(5)
20 
21 try:
22     while True:
23         print 'waiting for connection...'
24         # build client socket
25         tcpCliSock, addr = tcpSerSock.accept()
26         print '...connect from:', addr
27 
28         # accept data and process
29         while True:
30             data = tcpCliSock.recv(BUFSIZ)
31             if not data:
32                 break
33             tcpCliSock.send('[%s] %s' % (ctime(), data))
34 
35             # close client socket 
36             tcpCliSock.close()
37 except EOFError, KeyboardInterrupt:
38     tcpSerSock.close()
 1 # -*- coding:utf-8 -*-
 2 
 3 from socket import *
 4 
 5 # Address and Port 
 6 HOST = '127.0.0.1'
 7 PORT = 21567
 8 ADDR = (HOST, PORT)
 9 
10 # BufferSize
11 BUFSIZ = 1024
12 
13 #build socket 
14 tcpCliSocket = socket(AF_INET, SOCK_STREAM)
15 tcpCliSocket.connect(ADDR)
16 
17 while True:
18     data = raw_input('> ')
19     if not data:
20         break
21     # send data
22     tcpCliSocket.send(data)
23     # recv data
24     data = tcpCliSocket.recv(BUFSIZ)
25     if not data:
26         break
27     # show data
28     print data
29 tcpCliSocket.close()

无连接的UDP socket编程

 1 # -*- coding: utf-8 -*-
 2 
 3 from socket import *
 4 from time import ctime 
 5 
 6 # Address and Port 
 7 HOST = ''
 8 PORT = 8000
 9 ADDR = (HOST, PORT)
10 
11 # BufferSize
12 BUFFSIZE = 1024
13 # build socket
14 udpSerSock = socket(AF_INET, SOCK_DGRAM)
15 # bind socket
16 udpSerSock.bind(ADDR)
17 
18 try:
19     while True:
20         print 'waiting the message...'
21         data, addr = udpSerSock.recvfrom(BUFFSIZE)
22         print 'received the message: '+data+' from: ', addr
23         udpSerSock.sendto('[%s] %s' % (ctime(), data), addr)
24 except EOFError, KeyboardInterrupt:
25     udpSerSock.close()
 1 # -*- coding: utf-8 -*-
 2 
 3 from socket import *
 4 
 5 # Address and Port 
 6 HOST = 'localhost'
 7 PORT = 8000
 8 ADDR = (HOST, PORT)
 9 
10 # BufferSize
11 BUFSIZ = 1024
12 
13 # build socket 
14 udpCliSock = socket(AF_INET, SOCK_DGRAM)
15 
16 while True:
17     data = raw_input('> ')
18     udpCliSock.sendto(data, ADDR)
19     data = udpCliSock.recvfrom(BUFSIZ)
20     if not data:
21         break
22     print data 
23 udpCliSock.close()

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

 1 # -*- coding: utf-8 -*-
 2 
 3 from SocketServer import TCPServer as TCP, StreamRequestHandler as SRH 
 4 from time import ctime 
 5 
 6 # Address and Port
 7 HOST = ''
 8 PORT = 21567
 9 ADDR = (HOST, PORT)
10 
11 # BuffSize
12 BUFSIZ = 1024
13 
14 # build RequestHandler
15 class MyRequestHandler(SRH):
16     def handle(self):
17         print '...connected from: ', self.client_address
18         self.wfile.write('[%s] %s' % (ctime(), self.rfile.readline()))
19 
20 # build TCPServer
21 TCPServ = TCP(ADDR, MyRequestHandler)
22 print 'waiting for connection...'
23 # loop to process
24 TCPServ.serve_forever()
 1 # -*- coding:utf-8 -*-
 2 
 3 from socket import *
 4 
 5 # Address and Port 
 6 HOST = '127.0.0.1'
 7 PORT = 21567
 8 ADDR = (HOST, PORT)
 9 
10 # BufferSize
11 BUFSIZ = 1024
12 
13 while True:
14     # note: SocketServer 的请求处理器的默认行为是接受连接,
15     # 得到请求,然后就关闭连接,所以需要多次连接
16     tcpCliSock = socket(AF_INET, SOCK_STREAM)
17     tcpCliSock.connect(ADDR)
18 
19     # process data
20     data = raw_input('> ')
21     if not data:
22         break
23     tcpCliSock.send('%s\r\n' % data)
24 
25     data = tcpCliSock.recv(BUFSIZ)
26     if not data:
27         break
28     print data.strip()
29     tcpCliSock.close()
目录
相关文章
|
5天前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
5天前
|
程序员 开发者 Python
Python网络编程基础(Socket编程) 错误处理和异常处理的最佳实践
【4月更文挑战第11天】在网络编程中,错误处理和异常管理不仅是为了程序的健壮性,也是为了提供清晰的用户反馈以及优雅的故障恢复。在前面的章节中,我们讨论了如何使用`try-except`语句来处理网络错误。现在,我们将深入探讨错误处理和异常处理的最佳实践。
|
1月前
|
数据采集 存储 XML
深入浅出:基于Python的网络数据爬虫开发指南
【2月更文挑战第23天】 在数字时代,数据已成为新的石油。企业和个人都寻求通过各种手段获取互联网上的宝贵信息。本文将深入探讨网络爬虫的构建与优化,一种自动化工具,用于从网页上抓取并提取大量数据。我们将重点介绍Python语言中的相关库和技术,以及如何高效、合法地收集网络数据。文章不仅为初学者提供入门指导,也为有经验的开发者提供进阶技巧,确保读者能够在遵守网络伦理和法规的前提下,充分利用网络数据资源。
|
2月前
|
网络协议 Python
在Python中进行UDP(User Datagram Protocol)网络编程
在Python中进行UDP(User Datagram Protocol)网络编程
30 3
|
2月前
|
机器学习/深度学习 算法 PyTorch
python手把手搭建图像多分类神经网络-代码教程(手动搭建残差网络、mobileNET)
python手把手搭建图像多分类神经网络-代码教程(手动搭建残差网络、mobileNET)
43 0
|
12天前
|
数据采集 网络协议 API
python中其他网络相关的模块和库简介
【4月更文挑战第4天】Python网络编程有多个流行模块和库,如requests提供简洁的HTTP客户端API,支持多种HTTP方法和自动处理复杂功能;Scrapy是高效的网络爬虫框架,适用于数据挖掘和自动化测试;aiohttp基于asyncio的异步HTTP库,用于构建高性能Web应用;Twisted是事件驱动的网络引擎,支持多种协议和异步编程;Flask和Django分别是轻量级和全栈Web框架,方便构建不同规模的Web应用。这些工具使网络编程更简单和高效。
|
24天前
|
运维 安全 网络安全
Python灰帽子网络安全实践
旨在降低网络防范黑客的入门门槛,适合所有中小企业和传统企业。罗列常见的攻击手段和防范方法,让网站管理人员都具备基本的保护能力。Python 编程的简单实现,让网络运维变得更简单。各种黑客工具的理论和原理解剖,让人知其然更知道防范于未来。涉及互联网和局域网,让企业级网管工作更轻松。涵盖Linux&Windows 的知识点。
12 1
|
25天前
|
消息中间件 网络协议 API
Python语言的进程通讯及网络
Python语言的进程通讯及网络
|
28天前
|
机器学习/深度学习 算法框架/工具 Python
如何使用Python的Keras库构建神经网络模型?
如何使用Python的Keras库构建神经网络模型?
7 0
|
28天前
|
Python
如何使用Python的Requests库进行网络请求和抓取网页数据?
如何使用Python的Requests库进行网络请求和抓取网页数据?
12 0