实现功能:

  启动“服务器”、通过“客户端1”连接“服务器”,然后互发消息。在此过程中,有“客户端2”连接到“服务器”,此时,“客户端2”处于占线状态,必须要等“客户端1”退出之后才能与“服务器”互发消息。

知识点:

  s = socket.socket(family,type)  声明一个socket类型,同时创建连接(套接字),一般默认就可以

 family 参数:

  socket.AF_UNIX # 只能够用于单一的Unix系统进程间通信

  socket.AF_INET # IPV4 服务器之间网络通信

  socket.AF_INET6 # IPV6

 type 参数:

  socket.SOCK_STREAM # 流式socket 用于 TCP

  socket.SOCK_DGRAM # 数据报式socket 用于 UDP

主要方法:

  s.send(以字节类型发送,要发送的信息),返回值为要发送的字节数量,可能小于要发送的字节数。

  s.sendall(以字节类型发送,要发送的信息),发送所有。实际是内部递归调用send,发送所有内容。

  s.setblocking(True/False) accept或recv时是否阻塞,等待连接。若False,在接收时无数据,则会报错。

  s.recv(指定最多可以接收的字节数) 接收信息,以字符串形式返回

  s.recvfrom(指定最多可以接收的字节数) 接收信息,返回2个值(要接收的字符串,发送信息的地址)

  s.settimeout(多少秒)  设置等待多长时间之后端口连接,单位秒

  s.sendfile() 发送文件

  s.getpeername() 返回连接的远程地址:ip,端口

  s.getsockname() 返回自己的地址:ip,端口

  s.close() 关闭连接

  s.bind(address) 绑定地址,一般情况是元组形式:(ip,端口)

  s.listen(最大连接数) 开始监听传入连接,连接数不能无限大

  s.accept() 接收连接(阻塞式),并返回2个值(新的连接对象,连接地址),同时等待连接的到来。

  s.connect(address)  连接到指定地址(服务器)

  s.connect_ex(address)  连接到指定地址(服务器),连接成功返回0,否者返回错误代码

服务器端流程:声明、绑定监听、获取连接、接收、发送、关闭

1、创建连接(套接字)

2、绑定要监听的ip(本地)、端口

3、开始监听连接

4、连接客户端请求

5、接收客户端信息

6、给客户端发送信息

7、关闭连接

客户端流程:声明、连接、发送、接收、关闭

1、创建连接(套接字)

2、通过ip、端口连接服务器

3、给服务器端发送信息

4、接收服务器端信息

5、关闭连接

整体流程:服务器监听连接,客户端发送连接请求,服务器接收请求,互发信息

具体代码:

#!/user/bin env python
# author:Simple-Sir
# time:2020/7/22 17:01
import socket # 服务器端
s = socket.socket() # 声明一个socket类型,同时创建连接(套接字)
s.bind(('10.108.226.140', 6969)) # 绑定要监听的ip、端口
s.listen(5) # 开始监听连接
print('等待连接...')
while 1:
conn,address = s.accept() # 连接客户端请求(筛选连接对象,在服务器端生产新的连接)
ip_c, port_c = conn.getsockname() # 本地IP
ip_s, port_s = conn.getpeername() # 远程IP
print('{0}:{1}已连接上了。'.format(ip_s,port_s))
while 1:
data2 = conn.recv(1024) # 接收信息,字符串
if not data2:
print('客户端{0}:{1}已断开连接。'.format(ip_s,port_c))
break
print('客户端 {0}:{1}:{2}'.format(ip_s,port_s,data2.decode('utf-8')))
while 1:
info = input('服务器 {0}:{1}:'.format(ip_c, port_c))
if len(info) == 0:
print('不能输入空值,请重新输入!')
else:
break
conn.send(info.encode('utf-8')) # 发送信息,字节
s.close() # 关闭连接

服务器端

#!/user/bin env python
# author:Simple-Sir
# time:2020/7/22 17:35
import socket # 客户端
c = socket.socket() # 定义协议类型、链接对象
c.connect(('10.108.226.140',6969))
while 1:
ip_c,port_c = c.getsockname() # 本地IP
ip_s,port_s = c.getpeername() # 远程IP
info = input('客户端 {0}:{1}:'.format(ip_c,port_c))
if len(info) == 0:
continue
c.send(info.encode('utf-8'))
data1 = c.recv(1024)
print('服务器 {0}:{1}:{2}'.format(ip_s,port_s,data1.decode('utf-8')))
c.close()

客户端

运行结果:

启动“服务器”:

启动客户端1:

客户端1和服务器互发消息:

此时客户端2“呼叫”服务器,服务器还在与客户端1连接中,无法“接通”客户端2,客户端2处于等待状态:

客户端1与服务器断开连接,客户端2接通:

其他连接情况:

初识python:scoket 单用户互发消息的更多相关文章

  1. netty-2.客户端与服务端互发消息

    (原) 第二篇,客户端与服务端互发消息 与第一篇的例子类似,这里服务端需要三个类,客户端也需要三个类. 服务端关键代码如下:MyServer与上一个例子中的TestServer 差多,这里只列举不同的 ...

  2. Handler详解系列(四)——利用Handler在主线程与子线程之间互发消息,handler详解

    MainActivity如下: package cc.c; import android.app.Activity; import android.os.Bundle; import android. ...

  3. Handler具体解释系列(四)——利用Handler在主线程与子线程之间互发消息

    MainActivity例如以下: package cc.c; import android.app.Activity; import android.os.Bundle; import androi ...

  4. QQ互发消息

    private NewsData data; private void button3_Click(object sender, EventArgs e) //发送 { string x = text ...

  5. udp 内网穿透 互发消息

    还差实现内网终端,向服务器发送请求,要对方的内网连接自己,实现打洞.在同一网段,或者公网运行,可以相互聊天. 没有实现检测客户端下线功能. 1,服务器代码 package router; import ...

  6. 通过GUI制作一个简单的消息对话框互发消息

    public class LTS extends JFrame { private JPanel contentPane; private JTextField textField; private ...

  7. java Socket通信,客户端与服务端相互发消息

    1.通信过程 网络分为应用层,http.ssh.telnet就是属于这一类,建立在传输层的基础上.其实就是定义了各自的编码解码格式,分层如下: 2.Socket连接 上述通信都要先在传输层有建立连接的 ...

  8. 我们使用 Kafka 生产者在发消息的时候我们关注什么(Python 客户端 1.01 broker)

    之前使用 Kafka 的客户端消费者比较多一点,而且也是无脑订阅使用也没有深入了解过具体的参数.总的来说使用不够细节. 这次公司项目活动期间暴露非常多的问题,于是有了这篇文章. 首先我们来拆解一下 K ...

  9. 利用python itchat给女朋友定时发信息

    利用itchat给女朋友定时发信息 涉及到的技术有itchat,redis,mysql,最主要的还是mysql咯,当然咯,这么多东西,我就只介绍我代码需要用到的,其他的,如果需要了解的话,就需要看参考 ...

随机推荐

  1. System.exit(-1)和return 的区别

    对于只有一个单一方法的类或者系统来说是一样的,但是对于含有多个类和方法,且调用关系比较复杂时就不一样了. System.exit(-1)是指所有程序(方法,类等)停止,系统停止运行. return只是 ...

  2. Python @函数装饰器及用法(超级详细)

    函数装饰器的工作原理是怎样的呢?假设用 funA() 函数装饰器去装饰 funB() 函数,如下所示: #funA 作为装饰器函数 def funA(fn): #... fn() # 执行传入的fn参 ...

  3. 拷贝txt文本中的某行的数据到excel中

    package com.hope.day01;import java.io.*;import java.util.ArrayList;public class HelloWorld {    publ ...

  4. 阿里云发布CloudOps白皮书,ECS自动化运维套件新升级

    12月10 日,2021云上架构与运维峰会上,阿里云发布业界首部<云上自动化运维白皮书>(简称CloudOps白皮书),并在其中提出了CloudOps成熟度模型.同时,阿里云还宣布了ECS ...

  5. 网络协议之:基于UDP的高速数据传输协议UDT

    目录 简介 UDT协议 UDT的缺点 总结 简介 简单就是美.在网络协议的世界中,TCP和UDP是建立在IP协议基础上的两个非常通用的协议.我们现在经常使用的HTTP协议就是建立在TCP协议的基础上的 ...

  6. 用工具堆砌的DevOps 幻觉

    作者:顾宇 thoughtworks高级咨询师 在第一届 DevOpsDays结束后,DevOps 运动则如星火燎原之势在全球发展开来.随着 DevOps 思想的不断传播,相对的质疑和批评也从未停止过 ...

  7. Nginx配置正向代理

    目录 一.简介 二.配置 三.参数 一.简介 场景: 用于内网机器访问外网,就需要正向代理,类似VPN. 原理: A机器可以访问外网,而B,C,D机器只能内网,便可以设立正向代理,将B,C,D机器的访 ...

  8. 判断存在…Contains…(Power Query 之 M 语言)

    表函数 判断记录在表中是否存在 = Table.Contains( 表, 记录, {"指定列1",-, "指定列n"}) = Table.ContainsAll ...

  9. CSS选择器类型总结

    CSS选择器类型总结 1.通用选择器 一般用于给所有元素做一些通用性的样式设置,比如清除内边距.外边距等.但是效率比较低,尽量不要使用. * { margin: 0; padding: 0; } 2. ...

  10. Mysql 主从复制机制

    https://blog.csdn.net/girlgolden/article/details/89226528 MySQL异步复制及semi-sync半同步复制,它们都基于MySQL binlog ...