pythonsocket⽹络编程实验报告
⽹络编程实验报告
python_socket ⽹络编程
⼀、TCP编程
(⼀)、建⽴⼀个TCP服务器连接需要6个步骤:
1. 创建socket对象。调⽤socket构造函数:
socket=socket.socket(familly,type)
socket通信报文格式family的值可以是AF_UNIX(Unix域,⽤于同⼀台机器上的进程间通讯),也可以是AF_INET(对于IPV4协议的TCP和UDP),⾄于type参数,SOCK_STREAM (流套接字)或者SOCK_DGRAM(数据报⽂套接字),SOCK_RAW(raw套接字)。
2. 将socket绑定(指派)到指定地址上,socket.bind(address)
address必须是⼀个双元素元组,((host,port)),主机名或者ip地址+端⼝号。如果端⼝号正在被使⽤或者保
留,或者主机名或ip地址错误,则引发异常。
3. 绑定后,必须准备好套接字,以便接受连接请求。
socket.listen(backlog)
backlog指定了最多连接数,⾄少为1,接到连接请求后,这些请求必须排队,如果队列已满,则拒绝请求。
4. 服务器套接字通过socket的accept⽅法等待客户请求⼀个连接:connection,address=socket.accept()
调⽤accept⽅法时,socket会进⼊'waiting'(或阻塞)状态。客户请求连接时,⽅法建⽴连接并返回服务器。accept⽅法返回⼀个含有俩个元素的元组,形如(connection,address)。第⼀个元素(connection)是新的socket对象,服务器通过它与客户通信;第⼆个元素(address)是客户的internet地址。
5. 处理阶段,服务器和客户通过send和recv⽅法通信(传输数据)。
服务器调⽤send,并采⽤字符串形式向客户发送信息。send⽅法返回已发送的字符个数。服务器使⽤recv⽅法从客户接受信息。调⽤recv时,必须指定⼀个整数来控制本次调⽤所接受的最⼤数据量。recv⽅法在接受数据时会进⼊'blocket'状态,最后返回⼀个字符串,⽤它来表⽰收到的数据。如果发送的量超过recv所允许,数据会被截断。多余的数据将缓冲于接受端。以后调⽤recv时,
多余的数据会从缓冲区删除。
6. 传输结束,服务器调⽤socket的close⽅法以关闭连接。
(⼆)、建⽴⼀个TCP客户端连接则需要4个步骤:
1. 创建⼀个socket以连接服务器socket=socket.socket(family,type)
2. 使⽤socket的connect⽅法连接服务器t((host,port))
3. 客户和服务器通过send和recv⽅法通信。
4. 结束后,客户通过调⽤socket的close⽅法来关闭连接。
⼆,建⽴TCP连接
⾸先建⽴服务器程序。
创建套接字,绑定套接字,开始监听,就是⼀个while循环⼀直监听有没有消息连接。
客户端程序
创建套接字,连接,等待输⼊,发送。
同⼀台电脑结果在两个shell中演⽰。
局域⽹内交互测试信息:
作为服务器,来⾃IP地址为:192.168.1.101客户端的消息。
作为客户端,发送消息到IP地址为:192.168.1.101服务器
三,建⽴UDP连接
UDP的建⽴过程基本和TCP⼀样,看以下代码异同,这⾥不在熬述。建⽴服务器程序
创建套接字,开始监听,就是⼀个while循环⼀直监听有没有消息连接。建⽴客户端程序
创建套接字,while循环⼀直监听有没有消息连接。
两个shell中演⽰显⽰数据传送
局域⽹内的信息交互:
作为服务器,来⾃IP地址为192.168.1.101的消息。
作为客户端,向IP地址为192.168.1.101的服务器发送消息。
总结:⼀般的TCP和UDP连接服务器和客户端的内容和步骤。
TCP服务器端:
1 创建套接字,绑定套接字到当地地址,然后开始监听连接。就是socket,bind,listen。
2 进⼊循环,不断接受客户端的连接请求,然后接收传来的数据,当然也可以发送给对⽅数据。就是accept⼀个连接,然后recv数据。
3 接收完毕可以关闭套接字,close。
这个过程的伪代码如下:
ss=socket() #创建服务器套接字
ss.bind() #把本地地址绑到套接字上
ss.listen() #监听连接
inf_loop: #服务器⽆限循环
cs=ss.accept() #接受客户端的连接
comm._loop: #通信循环
cs.close() #关闭客户套接字
ss.close() #关闭服务器套接字
TCP客户端:
1 创建套接字,然后连接远端地址,socket ,connect。
2 建⽴连接之后开始发送数据。Send(data),当然可以从缓冲区读取服务器发来的数据。Recv(BUFF)
3 完毕后,关闭套接字。Close
伪代码如下:
cs=socket() #创建客户套接字
comm._loop: #通信循环
cs.send()/cs.recv() #对话
cs.close() #关闭套接字
UDP服务器端:
1 创建套接字,并绑定到当地地址socket,bing
2 直接接收数据从buffer。Recvfrom(),这个函数接受到数据,和sender的地址(主机号,端⼝号),当然也可以发送数据到客户端,⽤sendto(data,addr)
3 关闭套接字close()
伪代码:
Ss=socket() #创建套接字
ss.bind() #绑定
inf_loop: #⽆限循环
ss.close() #关闭套接字
UDP客户端:
1 创建套接字,socket
2 进⼊循环,发送接收数据sendto ,recvfrom
3 关闭套接字close()
伪代码:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论