《python核心编程》读书笔记--第16章 网络编程

时间:2023-12-22 15:36:56

在进行网络编程之前,先对网络以及互联网协议做一个了解。

推荐阮一峰的博客:(感谢)

http://www.ruanyifeng.com/blog/2012/05/internet_protocol_suite_part_i.html

--再去看一遍先--

--看完了--

16.1引言

客户端、服务器架构

服务器是一个软件或者硬件,用来想一个或多个客户端提供所需要的“服务”。其中,硬件是指打印机、文件服务器等。软件服务器提供的服务主要是程序的运行、数据的发送与接收、合并、升级、或其他的程序或数据操作。软件服务器有Web服务器、数据库服务器、窗口服务器等。

对于服务器而言,在提供服务之前需要进行一些设置。先要创建一个通讯端点,让服务器能够“监听”请求,然后需要将统一资源定位符(URL)在网络上广而告之,然后就可以提供服务了。

16.2套接字:通讯端点

1、什么是套接字

源IP地址和目的IP地址以及源端口号和目的端口号的组合称为套接字。其用于标识客户端请求的服务器和服务。是一种具有“通讯端点”概念的计算机网络数据结构。

套接字可以分为基于文件型和基于网络型。基于文件型的用来处理同一台主机上的程序(文件)之间的通讯。而网络型就是来处理网络之间的通讯的。

2、套接字地址:主机与端口

一个因特网地址由网络通讯所必需的主机与端口组成。合法的端口范围为0-65535,小于1024的用来作为系统端口,所以自己定义的(应用软件)端口只能是大于1024的。常用的端口号列表:http://www.iana.org/assignments/port-numbers

3、面向连接与无连接

套接字的类型只有两种:面向连接和无连接。

面向连接:也称“流套接字”(SOCK_STREAM)。在通讯之前先建立连接。该服务将保证数据能够实现无差错、无重复发送,并按顺序接收。流套接字之所以能够实现可靠的数据服务,原因在于其使用了传输控制协议,即TCP(The Transmission Control Protocol)协议。

无连接:即无需建立连接就进行通讯。就像邮政服务一样,数据的发送顺序和接收顺序关系不大,并且可能还收不到(中国邮政?)。那么,它的优点是没有建立连接的资源消耗。实现这种连接的是用户数据报协议(UDP)(SOCK_DGRAM)。

上面两种套接字使用网际协议(IP)来查找网络中的主机,这样形成的系统有两个协议组合来描述,TCP/IP和UDP/IP。

16.3Python中的网络编程

主要是stock模块的应用。

写一段TCP协议代码。

服务器端:

#-*- coding:utf-8 -*-
from socket import *
from time import ctime HOST = ''
PORT = 21567
BUFSIZ = 1024
ADDR = (HOST,PORT) #首先是创建套接字对象
tcpSerSock = socket(AF_INET,SOCK_STREAM)
tcpSerSock.bind(ADDR)
tcpSerSock.listen(5) #最多有多少个连接同时接进来 while True:
print 'wating for connection...'
tcpCliSock,addr = tcpSerSock.accept()
print '...connected from:',addr while True:
data = tcpCliSock.recv(BUFSIZ)
if not data:
break
tcpCliSock.send('[%s] %s' % (ctime(),data))
tcpCliSock.close() tcpSerSock.close()

客户端:

#-*- coding:utf-8 -*-
from socket import *
import time HOST = "localhost"
PORT = 21567
BUFSIZ = 1024
ADDR = (HOST,PORT) tcpCliSock = socket(AF_INET,SOCK_STREAM)
tcpCliSock.connect(ADDR) while True:
data = 'hepeng' if not data:
break
tcpCliSock.send(data)
data = tcpCliSock.recv(BUFSIZ)
if not data:
break
print data
time.sleep(10) tcpCliSock.close()

16.4 SocketServer模块

SocketServer 是标准库中一个高级别的模块。用于简化实现网络客户端与服务器所心需的大量样板代码。该模块中,已经实现了一些可供使用的类。

服务器端:

#-*- coding:utf-8 -*-
from SocketServer import (TCPServer as TCP,StreamRequestHandler as SRH)
from time import ctime HOST = ''
PORT = 21567
ADDR = (HOST,PORT)
#print dir(SRH) #看一下有哪些属性和方法
class MyReqyestHandler(SRH):
"""docstring for MyReqyestHandler"""
def handle(self):
print '...connected from:',self.client_address
self.wfile.write('[%s] %s' % (ctime(),self.rfile.readline())) tcpServ = TCP(ADDR,MyReqyestHandler)
print 'waiting for connection...'
tcpServ.serve_forever()

客户端:

#-*- coding:utf-8 -*-

from socket import *
import time HOST = "localhost"
PORT = 21567
BUFSIZ = 1024
ADDR = (HOST,PORT)
#注意这里的处理方式与前面的不同了,每次都需要进行新的socket对象定义,这样就是每次循环都会再与服务器连接一次
while True:
tcpCliSock = socket(AF_INET,SOCK_STREAM)
tcpCliSock.connect(ADDR)
data = 'hepeng' if not data:
break
tcpCliSock.send('%s\r\n' % data) #我们使用的处理器类像文件一样操作套接字,所以我们每次都要发送行结束字符(回车与换行〉
data = tcpCliSock.recv(BUFSIZ)
if not data:
break
print data.strip()
time.sleep(10)
tcpCliSock.close()

16.5 Twisted框架

Twisted 是一个完全事件驱动的网络框架。它允许你使用和开发完全异步的网络应用程序和协议。它为你创建一个完整系统提供了很大的帮助。系统中可以有:网络协议、线程、安全和认证、聊天/即时通讯、数据库管理、关系数据库集成、Wed/Internet、电子邮件、命令行参数、图形界面集成等。

推荐博客:

http://blog.sina.com.cn/s/blog_704b6af70100py9f.html