python网络编程:socket、服务端、客户端
本文内容:
- socket介绍
- TCP:
- 服务端
- 客户端
- UDP:
- 服务端
- 客户端
首发时间:2018-02-08 01:14
修改:
- 2018-03-20 :重置了布局,增加了UDP
什么是socket:
TCP:
- 如果使用socket模块来创建TCP客户端和服务端:
- 首发需要导入模块:import socket
- 然后创建过程在下面
服务端:
TCP服务端一般需要下面几个操作:建立,绑定IP地址和端口,监听端口,等待连接,接收数据,传输数据 ,关闭连接
- 建立:server=socket.socket(socket.AF_INET, socket.SOCK_STREAM) 【参数默认就是socket.AF_INET, socket.SOCK_STREAM】
- 绑定端口:server.bind(('IP地址',端口)),【地址和端口号是一个 tuple 】
- 监听:server.listen()
- 接受连接: conn,addr=server.accept(),返回值是一个连接实例和一个地址,地址是连接过来的客户端地址,而数据操作要利用这个连接实例
- 传输数据:conn.send(data),【传输的数据必须是字节流,所以对字符串数据需要使用encode() 】
- 接收数据read:conn.recv(size),【传输的数据必须是字节流,size是接收的字节数,如果需要转成Unicode,需要使用decode() 】
- 关闭连接close:close()
import socket
server=socket.socket()#建立socket server.bind(('localhost',1234))#绑定
server.listen()#监听
print("开始等待。。。")
conn,addr=server.accept()#接收连接
print("连接成功")
data=conn.recv(1024)#接收数据
print(data.decode())
conn.send(data)#发送数据 server.close()#关闭连接 print("--------------------")
- 上述代码存在一个问题:只能接受一次连接,连接结束后,服务端socket将关闭,更改成不立即关闭能等待下一个连接的:
#服务器端 import socket
server = socket.socket()
server.bind(('localhost',1234)) #绑定ip和端口
server.listen(5) #监听 while True:
print("开始等待")
conn, addr = server.accept()
print(conn, addr)
print("客户端连接")
while True:
data = conn.recv(1024)
print("recv:",data)
if not data: #当data=0时为真
print("连接断开...")
break
conn.send(data) server.close()
注:上述代码中在linux中正常运行,在windows中会报错!
如果要在windows中运行,需要捕获异常:
#服务器端 import socket
server = socket.socket()
server.bind(('localhost',1234)) #绑定ip和端口
server.listen(5) #监听 while True:
print("开始等待")
conn, addr = server.accept()
print(conn, addr)
print("客户端连接")
while True:
try:
data = conn.recv(1024)
print("recv:",data)
if not data: #当data=0时为真
print("连接断开...")
break
conn.send(data)
except ConnectionResetError as e:
print(e)
break server.close()
客户端:
TCP客户端一般需要下面几个操作:建立socket,连接远程socket,传输数据 ,接收数据,关闭连接
- 建立:client=socket.socket()
- 连接:client.connect(('IP地址',端口)),其中地址和端口号是一个 tuple
- 传输数据:client.send(data),传输的数据必须是字节流,所以对字符串数据需要使用encode()
- 接收数据recv:client.recv(size),传输的数据是字节流,如果需要转成Unicode,需要使用decode()
- 关闭连接close:close()
import socket
client=socket.socket()#建立socket
client.connect(('localhost',1234))#连接
client.send("你好".encode())#发送数据
data=client.recv(1024)#接收数据
print(data.decode()) client.close()#关闭连接
- 上述代码存在一个问题:只能发送一次数据,发生完数据就会断开连接,改成可以多次发送数据,不自动断开的【前提是服务端能接收多次】:
import socket client=socket.socket() client.connect(('localhost',1234))
while True:
cmd=input(">>")
if len(cmd)==0:
continue
client.send(cmd.encode())
cmd_res=client.recv(1024)
print(cmd_res.decode()) client.close()
UDP:
服务端:
UDP服务端通常有以下几个操作:创建socket,绑定端口,传输数据,接收数据
- 创建socket:server=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
- 绑定端口:server.bind(addr),【addr是一个元组,内容为(地址,端口)】
- 接收数据:data,client_addr=server.recvfrom(1024)
- 传输数据:server.sendto(data,client_addr)
import socket
import time
server=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
server.bind(("localhost",1234)) start_time=time.time()
while True:
data,addr=server.recvfrom(1024)
print(data,addr)
server.sendto("hello".encode(),addr)
time.sleep(1)
if time.time()-start_time>30:
break server.close()
客户端:
UDP客户端通常有以下几个操作:创建socket,传输数据,接收数据
- 创建socket:client=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
- 传输数据:server.sendto(data,addr),【addr是一个元组,内容为(地址,端口)】
- 接收数据:data,server_addr=client.recvfrom(1024)
import socket,time client=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
addr=("localhost",1234)
start_time=time.time()
while True: client.sendto(time.ctime().encode(),addr) data,addr= client.recvfrom(1024)
print(data)
time.sleep(1)
if time.time()-start_time>30:
break client.close()
python网络编程:socket、服务端、客户端的更多相关文章
- python 并发编程 socket 服务端 客户端 阻塞io行为
阻塞io行为 server.accept server.recv client.send recv,accept 分为两个阶段 1.wait for data 对方把数据经过网络延迟送到自己的操作系 ...
- python网络编程TCP服务多客户端的服务端开发
#服务多客户端TCP服务端开发 2 #方法说明 3 """ 4 bind(host,port)表示绑定端口号,host是ip地址,ip地址一般不进 行绑定,表示本机的任何 ...
- python网络编程socket /socketserver
提起网络编程,不同于web编程,它主要是C/S架构,也就是服务器.客户端结构的.对于初学者而言,最需要理解的不是网络的概念,而是python对于网络编程都提供了些什么模块和功能.不同于计算机发展的初级 ...
- Day07 - Python 网络编程 Socket
1. Python 网络编程 Python 提供了两个级别访问网络服务: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口 ...
- Python网络编程socket
网络编程之socket 看到本篇文章的题目是不是很疑惑,what is this?,不要着急,但是记住一说网络编程,你就想socket,socket是实现网络编程的工具,那么什么是socket,什么是 ...
- Python 网络编程——socket
一 客户端/服务器架构 客户端(Client)服务器(Server)架构,即C/S架构,包括 1.硬件C/S架构(打印机) 2.软件C/S架构(web服务) 理想/目标状态—— 最常用的软件服务器是 ...
- Python网络编程—socket(一)
从今天开始python基础就介绍完毕了,下面我们将进阶到socket网络编程的介绍,那么socket是什么呢?我们带着这个问题开始今天的介绍: 一.socket初探 socket通常也称作" ...
- TCP Socket服务端客户端(二)
本文服务端客户端封装代码转自https://blog.csdn.net/zhujunxxxxx/article/details/44258719,并作了简单的修改. 1)服务端 此类主要处理服务端相关 ...
- 在python中编写socket服务端模块(二):使用poll或epoll
在linux上编写socket服务端程序一般可以用select.poll.epoll三种方式,本文主要介绍使用poll和epoll编写socket服务端模块. 使用poll方式的服务器端程序代码: i ...
随机推荐
- django 中文入门文档
django中文入门文档:阅读地址
- spring boot 集成 Filter 的两种方式
两种方式:(两种方式同时存在时,@Bean优先@ServletComponentScan实例化,生成两个对象) 1)@ServletComponentScan注解+@WebFilter注解 2)@Be ...
- 使用 Notification API 开启浏览器桌面提醒
Notifications API 允许网页控制向最终用户显示系统通知 —这些都在顶级浏览上下文视口之外,因此即使用户已经切换标签页或移动到不同的应用程序,也可以显示.该API被设计成与不同平台上的现 ...
- 快速排序——Quick Sort
基本思想:(分治) 先从数列中取出一个数作为key值: 将比这个数小的数全部放在它的左边,大于或等于它的数全部放在它的右边: 对左右两个小数列重复第二步,直至各区间只有1个数. 辅助理解:挖坑填数 初 ...
- SQL 必知必会·笔记<9>使用子查询
子查询(subquery),即嵌套在其他查询中的查询. 1. 利用子查询进行过滤 SELECT 语句中,子查询总是从内向外处理.示例: SELECT cust_name, cust_contact F ...
- resin4.0.25 安装配置 及结合eclipse开发
resin4.0.25 安装配置 及结合eclipse开发 本文大部分内容是对官网的翻译,及自己配置后的一些体会. 一. 基于win ,resin基本安装1,安装jdk1.6或更高版本2,配置环境 ...
- linux下xdebug的安装和配置方法
xdebug简介 Xdebug是一个开放源代码的PHP程序调试器(即一个Debug工具),可以用来跟踪,调试和分析PHP程序的运行状况. xdebug安装 首先让php错误显示,只需要修改php.in ...
- git第九节---git命令实战
1. git 项目创建 mkdir git-command 2.git 配置 git config --list 配置用户名 邮箱 git config user.name 'XXX' --loca ...
- BizTalk Orchestration execute Flat file disassembler ReceivePipeline
需求是这样,在一个inbound XML中有个一点节点使用平文件的方式存放,还要解析比如固定长度或根据特殊字符截取字段 也就是需要在流程里面先把输入的XML的节点先读出来,这个方式有很多可以直接升级属 ...
- /proc文件系统(一):cpuinfo
0. 前言 /proc 文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间. 它以文件系统的方式为内核与进程提供通信的接口.用户和应用程序可以通过/proc得到系统的信息,并可以改变内核的某 ...