python写一个聊天程序_python实现一个简单的网络聊天程序-程序员宅基地

技术标签: python写一个聊天程序  

一、Linux Socket

1.Linux Socke基本上就是BSD Socket(伯克利套接字)

伯克利套接字的应用编程接口(API)是采用C语言的进程间通信的库,经常用在计算机网络间的通信。BSD Socket的应用编程接口已经是网络套接字的抽象标准。大多数其他程序语言使用一种相似的编程接口。由于伯克利套接字是第一个socket,大多数程序员很熟悉它们,所以大量系统把伯克利套接字作为其主要的网络API。

主要的头文件如下,不同的系统可能具体不同。

BSD socket 核心函数和数据结构。

AF_INET 和AF_INET6 地址家族和他们对应的协议家族PF_INET 和PF_INET6。在互联网编程中广泛使用,包括IP地址以及TCP和UDP端口号。

PF_UNIX/PF_LOCAL 地址家族。用于运行在一台计算机上的程序间的本地通信,不用在网络中。

和IP地址相关的一些函数。

把协议名和主机名转化成数字的一些函数。

2.API函数

这些是伯克利套接字提供的库函数:

(1)socket() 创造某种类型的套接字,分配一些系统资源,用返回的整数识别。

(2)bind() 一般是用在服务器这边,和一个套接字地址结构相连,比如说是一个特定的本地端口号和一个IP地址。

(3)listen()用在服务器一边,导致一个绑定的TCP套接字进入监听状态。

(4)connect() 用在客户机这边,给套接字分配一个空闲的端口号。比如说一个TCP套接字,它会试图建立一个新的TCP连接。

(5)accept() 用在服务器这边。从客户机那接受请求试图创造一个新的TCP连接,并把一个套接字和这个连接相联系起来。

(6)send() and recv(), or write() and read(),or sendto() and recvfrom()用来接收和发送数据。

(7)close() 关闭连接,系统释放资源。

(8)gethostbyname() and gethostbyaddr()用来解析主机名和地址。

(9)select() 、poll() 处理多个连续的读、写饿错误状态。

(11)getsockopt() 得到对应socket的选项值。

(12)setsockopt() 设置对应socket的选项值。

二、Python实现网络通信

网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket。python中socket模块为操作系统的socket实现提供了一个python接口。

1.socket的相关函数:

(1)socket():用于创建与指定的服务提供者绑定socket。

函数原型为:socket=socket.socket(familly,type)

参数说明:

familly:指定协议的地址家族,可为AF_INET或AF_UNIX。AF_INET家族包括Internet地址,AF_UNIX家族用于同一台机器上的进程间通信。

type:指定套接字的类型。

(2)bind():bind()函数可以将本地地址与一个socket绑定在一起.

函数原型为:socket.bind( address )

参数address是一个双元素元组,格式是(host,port)。host代表主机,port代表端口号。

(3)listen():listen()函数可以将socket设置为监听接入连接的状态。

函数原型为:listen(backlog)

参数backlog指定等待连接队列的最大长度。

(4)connect():connect()函数用于连接到address处的socket。

函数原型为:socket.connect(address)

参数address是一个双元素元组,格式是(host,port)。host代表主机,port代表端口号

(5)accept():在服务器端调用listen()函数监听接入连接后,可以调用accept()函数来等待接受连接请求。

函数原型为:(connection,address)=socket.accept()

用accept()方法后,socket会进入waiting状态。客户请求连接时,accept()方法会建立连接并返回服务器。accept()方法返回一个含有两个元素的元组(connection,address)。第一个元素connection是新的socket对象,服务器必须通过它与客户通信;第二个元素address是客户的Internet地址。

(6)recv():调用recv()函数可以从已连接的socket中接收数据。

函数原型为:buf = sock.recv(size)

参数sock是接收数据的socket对象,参数size指定接收数据的缓冲区的大小。recv()的函数的返回接收的数据。

(7)send():调用send()函数可以在已连接的socket上发送数据。

函数原型为:sock.recv(buf)

参数sock是在已连接的socket上发送数据。参数buf是也要已连接的Socket上发送数据。

(8)close():close ()函数用于关闭一个socket,释放其所占用的所有资源。

函数原型为:sock.closesocket();

参数s表示要关闭的socket。

可以在Linux系统下查看socket模块:

964d27bc18333d326625555e6d313d8053c.png

通过比较可以看出,再socket模块中并没有上述的bind(),listen(),accept()等函数。

这是因为它们都是继承自_socket模块。而_socket是在链接库里的,也就是说它不是用python实现的,而是socket操作的C实现,这个是非常底层的操作。socket.py是用py代码把C实现的模块的封装起来之后的模块,供人使用,在不同系统_socket的位置不一样。

再查看_socket模块:

5c1c8354fc8baf054d41010ffd38900a5df.png

这下可以看到我们在编程中需要用到的那些函数了。

2.TCP/编程实现:

socket编程需要两端,一般来说,需要一个服务端(Server),一个客户端(Client)。如图:

e68483cb17498da10f5e51677485a081d7d.png

TCP服务端编程:

服务端连接步骤:

(1)创建socket对象

(2)使用bind方法,绑定IP地址,Address和端口Port

(3)使用listen开始监听,在上面以绑定的地址上

(4)使用accept开始等待连接进来,获取用于传送数据的socket对象和addr。注意使用accept会发生阻塞,惯用放在新的线程里面

(5)接收数据recv

代码:

importsocket

sk= socket.socket() #默认是AF_INET、SOCK_STREAM

address = ('127.0.0.1', 9000)

sk.bind(address)#将主机号与端口绑定到套接字

sk.listen(3) #设置并启动TCP监听器

print('waitting......')whileTrue:

conn, addr= sk.accept() #被动接受TCP连接,一直等待连接到达

print('连接到达',addr)whileTrue:

data= conn.recv(1024) #接收TCP消息,并制定最大长度

if notdata:print('连接已断开!')

conn.close()break

print(str(data, 'utf8'))

inp= input('>>')

conn.send(bytes(inp,'utf8')) #向客户端回送信息

TCP客户端编程:

客户端连接步骤:

(1)创建Socket对象

(2)连接到远端服务端的IP和port端口, connect方法

(3)传输数据:send发送数据;recv接收数据, 会阻塞

(4)关闭连接,释放资源

代码:

importsocket

sk= socket.socket() #默认是AF_INET、SOCK_STREAM

address = ('127.0.0.1', 9000)

sk.connect(address)#连接服务端

whileTrue:

inp= input('>>')if inp == 'exit':breaksk.send(bytes(inp,'utf8')) #向服务端发送信息

data = sk.recv(1024)print(str(data, 'utf8'))else:

sk.close()

运行结果:

服务端:

652b9f21320b563eb096d2f0370b9672073.png

客户端:

ba4f3eabaff42195d9ea7651d800e942fd3.png

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39607620/article/details/110333372

智能推荐

响应式编程实现异步RPC,提升xxl-job调度吞吐量-程序员宅基地

文章浏览阅读1.1k次。在xxl-job中,RPC即用于调度中心请求执行器执行job、kill job,也用于执行器请求调度中心主动注册、执行结果上报。xxl-job实现的RPC类似Feign框架,是基于http..._xxljob 用的什么协议

C++ Json到对象的自动序列化和反序列化工作_c++ json序列化和反序列化-程序员宅基地

文章浏览阅读555次,点赞17次,收藏22次。JSERIALIZE_DEF_OBJECTLIST(Person,Object,objectList) //接受json中的objectList对象数组,对象数组使用此宏定义。JSERIALIZE_DEF_OBJECTTYPE(Person,Son,son) //接受json中的son对象,对象成员使用此宏定义。//输出反序列化结果。

DOSBOX 0.74模拟器安装Windows 95_dosbox imgmount-程序员宅基地

文章浏览阅读7.8k次,点赞2次,收藏6次。DosBox本身带有5.0版的DOS系统,启动后虚拟一个Z盘存放有Dosbox特有的外部指令,如config.com、imgmount.com等,经测试,可以顺利安装各版本的windows 3.1系统,但是不能安装win95,需要用原版的dos镜像启动才能安装。1. 获取启动盘镜像文件 下载Win95启动软盘镜像文件,名为boot.img,放到DosBox 0.74的目录下。2. 制作硬盘镜像文件_dosbox imgmount

呼叫转移的普适性及编程实现_电话自动转移程序开发-程序员宅基地

文章浏览阅读53次。总结来说,呼叫转移是一种方便的电话通信功能,在编程中可以通过使用电话服务提供商的API来实现。然而,实际的实现可能因具体的服务提供商而有所不同,你需要参考相应的文档或与服务提供商联系以获取准确的实现细节。在函数内部,我们构建了一个API请求的有效载荷(payload),其中包含了原始电话号码和目标电话号码。在编程中,呼叫转移的实现涉及使用电话通信协议和相应的编程语言。需要注意的是,实际的呼叫转移功能的实现可能因电话服务提供商的不同而有所差异。首先,我们需要确保已经安装了Python的开发环境和相应的库。_电话自动转移程序开发

FLink聚合性能优化--MiniBatch分析_flink mini-batch-程序员宅基地

文章浏览阅读5.4k次,点赞4次,收藏15次。[@ TOC]一、MiniBatch的演进思路1、MiniBatch版本Flink 1.9.0 SQL(Blink Planner) 性能优化中一项重要的改进就是升级了微批模型,即 MiniBatch(也称作MicroBatch或MiniBatch2.0),在支持高吞吐场景发挥了重要作用。MiniBatch与早期的MiniBatch1.0在微批的触发机制略有不同。原理同样是缓存一定的数据后..._flink mini-batch

EasyExcel导入_easyexcel 对接multipartfile-程序员宅基地

文章浏览阅读808次,点赞6次,收藏6次。导入依赖<dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.6</version></dependency>Controllerimport java.text.ParseException;import org.springframework._easyexcel 对接multipartfile

随便推点

2022考研日语71分自学经验贴;日语可以自学吗?-程序员宅基地

文章浏览阅读1.2k次,点赞3次,收藏5次。目录1 个人对考研日语的评价1 日语VS英语2 考研日语适合哪些人,什么时候开始3 找到可以选日语的院校专业的方法4 高考日语自学经历(供参考)4.1 学习过程4.2 必用资料5 考研日语自学+作文课经历(供参考)5.1 资料相关5.2 完型(20分)5.3 阅读(40分)5.4 翻译(15分)5.5 作文(25分)end实在受不了英语应试的折磨,高考和考研都用了203日语替换了英语(高考127分,考研估分65-70分)1 个人对考研日语的评价我是有了高考127分的基础(大概N3水平,N2擦线水平),

JVM性能优化 (一) 初识JVM-程序员宅基地

文章浏览阅读703次,点赞22次,收藏24次。到这里文章就讲完了,有疑问的兄弟可以在下面讨论或留言,也祝大家在今年开开心心,健健康康,能够拥有一份好工作,大家加油,我是牧小农!自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

通过手动给upx去壳简单了解逆向_upx脱壳机-程序员宅基地

文章浏览阅读1.7k次。对于像我这种想入门逆向的,这种方式真的可以培养兴趣,也从中学到了很多知识,我也不会仅仅止步于脱upx的。[外链图片转存中…(img-xkCBlSoD-1693021558445)]即可。对于像我这种想入门逆向的,这种方式真的可以培养兴趣,也从中学到了很多知识,我也不会仅仅止步于脱upx的。_upx脱壳机

Quartz定时任务调度cron 表达式时间格式(☆)_cron表达式 下午5点30-程序员宅基地

文章浏览阅读890次。cron 表达式的格式 Quartz Cron 表达式支持到七个域 名称 是否必须 允许值 特殊字符 秒 是 0-59 ..._cron表达式 下午5点30

SQL Server 疑难杂症--转换科学计数法的数值字符串为decimal类型_mssql 字符串转decimal 精度问题-程序员宅基地

文章浏览阅读1.8k次。今天在操作数据库时,需要将字符串转换成Decimal类型。代码如下:selectcast('0.12'asdecimal(18,2));selectconvert(decimal(18,2),'0.12');当需要将科学计数法的数字字符串转换成Decimal时,这2种写法都报错:Msg 8114, Level 16, State 5, Line 1Erro..._mssql 字符串转decimal 精度问题

soul源码解读(十八)-- resilience4j插件原理分析_resilience4j timeoutduration含义-程序员宅基地

文章浏览阅读553次。soul源码解读(十八)resilience4j插件使用resilience4jresilience4j插件是网关用来对流量进行限流与熔断的可选选择之一。resilience4j为网关熔断限流提供能力。插件使用1.启动 admin,打开 resilience4j 插件开关2.在 bootstrap 项目的 pom 文件引入 resilience4j 插件的相关依赖,启动 bootstrap <!-- soul resilience4j plugin start--> <_resilience4j timeoutduration含义

推荐文章

热门文章

相关标签