day24_python_1124
1 复习
2 TCP-UDP协议
3 tcp协议的socket
4 复杂tcp协议的socket
5 带退出的聊天程序
6 时间练习demo
7 粘包现象
1.复习
# 网络编程概念
# 两大开发架构
# C/S B/S
# ip地址
# mac地址
# 内网/外网
# 交换机 : 单播、广播、组播
# 在一个局域网内的通信
# 二层/数据链路层 - osi七层协议
# 数据链路层的协议 :arp协议(通过一台机器的ip地址找到mac地址)
# 数据链路层的网络设备 : 交换机、网卡
# 路由器 :
# 局域网与局域网之间的连接工具
# 三层/网络层 - osi七层协议
# 网络层的协议 :ip协议
# 网络层的设备 :路由器、三层交换机
# 网关
# 一个局域网要想访问局域网外部的其他机器,都要通过统一的网关接口
# 子网掩码
# 判断两台机器是否在同一个局域网内
# 端口来定位某一台机器上的某一个服务
# 如何定位你的网络中能够找到的唯一一台机器+服务 ip + 该服务的端口号
2.tcp-udp协议
# osi七层协议的传输层 : TCP/UDP协议
# 这两个协议标志着我们的数据传递的方式
# tcp协议 :语音通话
# 必须先接通电话,同一时刻只能和一个人聊天,传输比较稳定,慢
# 可以发送任意长度的消息
# udp协议 :发微信
# 不需要接通 只要互相知道ip 端口就可以通信 ,同时可以和多个人聊天,但是传输相对不稳定,传输速度快
# 不能传输过长的消息
# tcp :发送文件(邮件)、下载安装包、上传、下载电影、从网盘上上传、下载文件
# udp :即时通信类的、在线播放
# tcp协议
# 为什么它传输稳定、可靠?
# 先建立连接
# 三次握手、四次挥手
# tcp协议和udp协议各自的特点
3 tcp协议的socket
server
import socket #套接字
sk = socket.socket() #先买一部手机sk.bind(('127.0.0.1',9600)) #绑定一个电话卡 PS本地回环地址127.0.0.1sk.listen() #开机 py3.4后()里可以不加数字conn,addr = sk.accept() #阻塞,直到有客户端来连接,三次握手建立连接print(addr) # ('127.0.0.1', 52171)print(conn) # 包含addr的一些信息print(sk) # 不包含addr的conn信息conn.send(b'hello')msg = conn.recv(1024)print(msg)conn.close() #四次挥手,断开连接sk.close() #关机
client
import socket
sk = socket.socket()sk.connect(('127.0.0.1',9600))msg = sk.recv(1024)print(msg)sk.send(b'byebye')sk.close()
4 复杂tcp协议的socket
PS:连续相互对话
server
sk = socket.socket()sk.bind(('127.0.0.1',9600))sk.listen()conn,addr = sk.accept() #conn,addr只是可以换其他代替
while True: send_msg = input('msg : ') conn.send(send_msg.encode()) msg = conn.recv(1024).decode() print(msg)conn.close()sk.close()
client
import socket
sk = socket.socket()sk.connect(('127.0.0.1',9600))
while True: msg = sk.recv(1024).decode() print(msg) send_msg = input('msg : ') sk.send(send_msg.encode())
sk.close()
5 带退出的聊天程序
server
import socket
sk = socket.socket()sk.bind(('127.0.0.1',9600))sk.listen()
conn,addr = sk.accept()
while True: send_msg = input('msg : ') # q conn.send(send_msg.encode()) # send(q) if send_msg == 'q':break msg = conn.recv(1024).decode() if msg == 'q':break print(msg)
conn.close()
client
import socket
sk = socket.socket()sk.connect(('127.0.0.1',9600))
while True: msg = sk.recv(1024).decode() if msg == 'q':break print(msg) send_msg = input('msg : ') sk.send(send_msg.encode()) if send_msg == 'q':break
sk.close()
6 时间练习demo
server
import socketimport time
sk = socket.socket()sk.bind(('127.0.0.1',9600))sk.listen()
while True: conn,addr = sk.accept() fmt = conn.recv(1024) str_time = time.strftime(fmt.decode()) conn.send(str_time.encode()) conn.close()sk.close()
client
import socket
sk = socket.socket()sk.connect(('127.0.0.1',9600))sk.send(b'%Y/%m/%d %H:%M:%S')msg = sk.recv(1024).decode()print(msg)sk.close()
补充:
# str 字符串数据类型
# bytes 字节数据类型
# 中 :gbk bytes 100100110101
# 中 :utf8 bytes 100111100001
# send(bytes)
# bytes = recv()
# 我们要看 是看str
# 我们在发送数据之前是str,发送的是bytes
# 就需要对str进行编码,str.encode('utf-8')结果是一个bytes
# 我们在接受数据的时候 收到的也是bytes类型
# 我们要想看懂必须把bytes解码,bytes.decode('utf-8')结果就是一个字符串
7 粘包现象
server
import struct
import socket
sk = socket.socket()
sk.bind(('127.0.0.1',9000))
sk.listen()
conn,addr = sk.accept()
send_msg = input('>>>').encode()
bytes_len = struct.pack('i',len(send_msg))
conn.send(bytes_len)
conn.send(send_msg) # 粘包现象
conn.send(b'world')
conn.close()
sk.close()
# 1.发送端的粘包 合包机制 + 缓存区
# 2.接收端的粘包 延迟接受 + 缓存区
# 3.流式传输
# 电流 高低电压
# 所以我们说 tcp协议是无边界的流式传输
# 4.拆包机制
# 粘包现象
# 接收端不知道发送端给我发送了多长的数据
client
import struct
import socket
sk = socket.socket()
sk.connect(('127.0.0.1',9000))
bytes_len = sk.recv(4)
msg_len = struct.unpack('i',bytes_len)[0]
msg = sk.recv(msg_len)
print(msg.decode())
msg2 = sk.recv(5)
print(msg2)
sk.close()
解决方法一
import struct
ret = struct.pack('i',560000)
print(ret,len(ret))
ret1 = struct.pack('i',123)
print(ret1,len(ret1))
ret2 = struct.pack('i',902730757)
print(ret2,len(ret2))
res = struct.unpack('i',ret)
print(res[0])
res = struct.unpack('i',ret1)
print(res[0])
res = struct.unpack('i',ret2)
print(res[0])
day24_python_1124的更多相关文章
随机推荐
- VueScroller 使用
下载插件 npm install vue-scroller -D 引入插件: import Vue from 'vue'import VueScroller from 'vue-scroller' ...
- CEF 自定义用户协议(scheme)实现以二进制流的方式显示图片、视频、音频
转载:https://www.cnblogs.com/sinceret/p/10417941.html 转载:https://stackoverflow.com/questions/48811756/ ...
- 清北学堂北京大学冯哲神仙讲课day2
今天讲基础数据结构 首先讲(二叉搜索树) 保证左儿子小于右儿子,那么对于根节点来说.大于根节点的放到右子树递归,小于根节点的放在左子树 相等的呢?某大佬(老师)这么说: 删除的前提是找这个点在哪: 如 ...
- writeup
``` #签到题``` 请打开微信关注,发送give me flag,即可获得.```Encode````1.ACSCLL首先看到这类题,我们肯定是要使用ASCLL的(这么明显的提示大家肯定一眼就能看 ...
- HTML解析之BeautifulSoup
BeautifulSoup是一个用于从HTML和XML文件中提取数据的Python库.BeautifulSoup提供一些简单的.函数用来处理导航.搜索.修改分析树等功能.BeautifulSoup模块 ...
- 在Pycharm中使用Pandas时输出结果中列被省略的解决办法
在使用pycharm学习pandas的过程中我发现好多时候会发生不能输出所有列的情况,上网搜了一下,发现解决的办法是使用一个输出控制的函数. 在下面的代码中我们只是输出starbucks_store_ ...
- Visual Studio 禁用诊断工具
这里以 Visual Studio 2019 为例 调试 - 选项 调试 - 常规 - 禁用调试时启用诊断工具
- 20175312 2018-2019-2 《Java程序设计》第9周学习总结
20175312 2018-2019-2 <Java程序设计>第9周学习总结 教材学习内容总结 已依照蓝墨云班课的要求完成了第九章的学习,主要的学习渠道是PPT,和书的课后习题. 总结如下 ...
- 2019 年 Spread.NET 产品路线图(Roadmap)
前言 | 问题背景 2018年结束了,12月是Spread.NET的重要月份.我们发布了Spread.NET 12,我们期待着 2019 年令人兴奋的新年,这是Windows Forms开发人员有史以 ...
- Python+MapReduce实现矩阵相乘
算法原理 map阶段 在map阶段,需要做的是进行数据准备.把来自矩阵A的元素aij,标识成p条<key, value>的形式,key="i,k",(其中k=1,2,. ...