Python全栈开发:socket代码实例
客户端与服务端交互的基本流程
- 服务端server
#!/usr/bin/env python
# -*- coding;utf-8 -*-
import socket sk = socket.socket()
sk.bind(("127.0.0.1", 9999))
sk.listen(5)
while True:
conn, address = sk.accept()
conn.sendall(bytes("欢迎访问老男孩!",encoding="utf-8"))
while True:
ret_bytes = conn.recv(1024)
ret_str = str(ret_bytes, encoding="utf-8")
print(ret_str)
if ret_str == "q":
break
conn.sendall(bytes("答:" + "好!", encoding="utf-8")) - 客户端client
#!/usr/bin/env python
# -*- coding;utf-8 -*-
import socket obj = socket.socket()
obj.connect(("127.0.0.1", 9999))
ret_bytes = obj.recv(1024)
ret_str = str(ret_bytes, encoding="utf-8")
print(ret_str)
while True:
inp = input("请输入内容:\n 问:")
obj.sendall(bytes(inp, encoding="utf-8"))
if inp == 'q':
break
else:
ret = str(obj.recv(1024), encoding="utf-8")
print(ret)
obj.close()
粘包问题解决方案:一个类型文件发送完毕之后进行一次确认信息交互。
- server(粘包)
#!/usr/bin/env python
# -*- coding;utf-8 -*- import socket sk = socket.socket()
sk.bind(("192.168.1.107", 9999,)) # 传入元组
sk.listen(5) # 监听客户端请求,最多有五个客户端请求等待)
# 连接,客户端的地址信息(IP,port)
while True:
conn, address = sk.accept() # accept表示阻塞,等待连接请求
conn.sendall(bytes("欢迎访问老男孩!", encoding="utf-8"))
file_size = str(conn.recv(1024), encoding="utf-8")
print(file_size)
conn.sendall(bytes("开始吧!", encoding="utf-8"))
total_size = int(file_size)
has_recv = 0
with open("c11.py", "wb") as f:
i = 0
while True:
if total_size == has_recv:
print("接收完毕!")
break
data = conn.recv(1024)
f.write(data)
has_recv += len(data)
obj.close() - client(粘包)
#!/usr/bin/env python
# -*- coding;utf-8 -*-
import socket
import os obj = socket.socket()
obj.connect(("192.168.1.107", 9999))
result_bytes = obj.recv(1024) # 等待发送消息
result_str = str(result_bytes, encoding="utf-8")
print(result_str)
# 发送当前文件大小
file_size = os.stat("client(粘包).py").st_size
print("文件大小:" + str(file_size))
obj.sendall(bytes(str(file_size), encoding="utf-8"))
obj.recv(1024)
with open("client(粘包).py", "rb") as f:
seed_size = 0
for i, line in enumerate(f, 1):
obj.sendall(line)
seed_size += len(line)
if seed_size == file_size:
print("发送完毕!")
obj.close()
IO多路复用在socket中的运用:针对老用户和新用户,服务器做出不同的响应
- server服务端
#!/usr/bin/env python
# -*- coding;utf-8 -*-
"""
IO多路复用socket实例代码
"""
import socket
import select sk1 = socket.socket()
sk1.bind(("127.0.0.1", 8001))
sk1.listen(5)
inputs = [sk1, ]
info_sender = []
message = {} while True:
# select自动监听文件描述符,发生变化则放入r_list列表中
r_list, w_list, e_list = select.select(inputs, info_sender, [], 1)
# print("正在监听的对象数量:%d" % len(inputs))
for sk in r_list:
# sk 表示每个连接对象
if sk == sk1:
# 有新用户建立连接
conn, address = sk.accept()
conn.sendall(bytes("hello", encoding="utf-8"))
inputs.append(conn)
message[conn] = []
else:
# 有老用户发送信息
try:
date = str(sk.recv(1024), encoding="utf-8")
except Exception as e:
e_list.append(sk)
else:
if sk not in info_sender:
info_sender.append(sk)
message[sk].append(date) for sk in w_list:
re = message[sk][0]
del message[sk][0]
sk.sendall(bytes(re + "hello", encoding="utf-8"))
# 给我发送信息的对象,我回复了信息就要把它排除,不然前面有while循环,和for循环,就会不断给对方回复消息!
info_sender.remove(sk) for sk in e_list:
inputs.remove(sk) - 客户端client(client1,client2,client3):当用户第一次连接时执行相同的操作,支持多用户与服务器交互,客户端断开连接,服务器不受影响
#!/usr/bin/env python
# -*- coding;utf-8 -*-
import socket sk1 = socket.socket()
sk1.connect(("127.0.0.1", 8001))
while True:
content1 = str(sk1.recv(1024), encoding="utf-8")
a = []
print(content1)
while True:
inp = input(">>>")
if inp == "q":
a.append(inp)
break
else:
sk1.sendall(bytes(inp, encoding="utf-8"))
content2 = str(sk1.recv(1024), encoding="utf-8")
print(content2)
if a == ["q"]:
break
sk1.close()
Python全栈开发:socket代码实例的更多相关文章
- Python全栈开发:递归实例
#!/usr/bin/env python # -*- coding;utf-8 -*- """ 递归不能无限,python会限制递归深度,递归主要用于费布拉切数列 &q ...
- Python全栈开发【面向对象】
Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...
- Python全栈开发【模块】
Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...
- Python全栈开发【基础三】
Python全栈开发[基础三] 本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...
- python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)
昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...
- 学习笔记之Python全栈开发/人工智能公开课_腾讯课堂
Python全栈开发/人工智能公开课_腾讯课堂 https://ke.qq.com/course/190378 https://github.com/haoran119/ke.qq.com.pytho ...
- Python全栈【Socket网络编程】
Python全栈[socket网络编程] 本章内容: Socket 基于TCP的套接字 基于UDP的套接字 TCP粘包 SocketServer 模块(ThreadingTCPServer源码剖析) ...
- Python全栈开发【面向对象进阶】
Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...
- Python全栈开发【基础四】
Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...
- Python全栈开发【基础一】
Python全栈开发[第一篇] 本节内容: Python 的种类 Python 的环境 Python 入门(解释器.编码.变量.input输入.if流程控制与缩进.while循环) if流程控制与wh ...
随机推荐
- VS卸载不干净,再次安装盘符不能更改问题(转载)
下载文件,直接用. 链接:https://pan.baidu.com/s/1K1cbJUq_JC9DN2MoE6Z3RA 密码:cuad
- [转]gulp打包工具总结
与grunt类似,gulp也是构建工具,但相比于grunt的频繁IO操作,gulp的流操作能更快更便捷地完成构建工作.gulp借鉴了Unix操作系统的管道(pipe)思想,前一级的输出,直接变成后一级 ...
- HDU6447 YJJ's Salesman-2018CCPC网络赛-线段树求区间最值+离散化+dp
目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 Catalog Problem:Portal传送门 原题目描述在最下面. 1e5个点,问 ...
- 秒懂机器学习---k临近算法(KNN)
秒懂机器学习---k临近算法(KNN) 一.总结 一句话总结: 弄懂原理,然后要运行实例,然后多解决问题,然后想出优化,分析优缺点,才算真的懂 1.KNN(K-Nearest Neighbor)算法的 ...
- [转]C# 将类的内容写成JSON格式的字符串
将类的内容写入到JSON格式的字符串中 本例中建立了Person类,赋值后将类中内容写入到字符串中 运行本代码需要添加引用动态库Newtonsoft.Json 程序代码: using System; ...
- sudo apt-get update:Could not get lock /var/lib/apt/lists/lock解决办法
原文: http://blog.chinaunix.net/uid-26932153-id-3193335.html 今天更新时候出现了点小问题,一开始更新到一半,我嫌速度慢,就取消掉了. 更新了so ...
- 文本数据增量导入到mysql
实现思路: 实现Java读取TXT文件中的内容并存到内存,将内存中的数据和mysql 数据库里面某张表数据的字段做一个比较,如果比较内存中的数据在mysql 里存在则不做处理,如果不存在则 ...
- json、pickle和base64
json.dumps() 用于将dict类型的数据转成str,因为如果直接将dict类型的数据写入json文件中会发生报错,因此在将数据写入时需要用到该函数. json.dump() 用于将dict类 ...
- uoj192 【UR #14】最强跳蚤
题目 和成爷达成一致,被卡随机的话就是过了 考虑一个完全平方数的所有质因子次幂一定是偶数,于是对于每一条边我们都只保留其出现次数为奇数的质因子 注意到有一个点的\(w\leq 80\),于是考虑状压质 ...
- 2019-2020 ICPC, NERC, Northern Eurasia Finals
A. Apprentice Learning Trajectory rdc乱编的做法 考虑贪心,每次会选择结束时间最早的. 设当前时间为 \(x\),那么可以区间有两类 a) \(l_i \leq x ...