本地回环地址:127.0.0.1

简易版服务端:

import socket

server = socket.socket() # 就比如买了一个手机
server.bind(("127.0.0.1",8080)) # bind中绑定的是IP地址和端口号,注意是一个元组,就比如,将手机卡,插入了手机
server.listen(5) # 半连接池,最大等待连接数为5个,就比如开机
conn,address = server.accept() # 接听电话等着别人给你打电话

date = conn.recv(1024) # 听别人说话,接收1023个字节数
print(date)
conn.send(b"hello") # 给别人回话


conn.close() # 挂断电话
server.close() # 关机

简易版客户端:

import socket

client = socket.socket() #拿电话
client.connect(("127.0.0.1",8080)) #绑定的是IP地址和端口号,也是一个元组 拨号

client.send(b"hello") # 对别人发消息

date = client.recv(1024) #接收别人说话,没次接收1024个字节
print(date)

client.close() # 挂电话

注意:在写服务端和客户端的时候send和recv需要一一对应,不能再两边都出现,recv是跟内存要数据,至于数据的来源无需考虑

粘包:

服务端:

import socket

server = socket.socket() # 就比如买了一个手机
server.bind(("127.0.0.1",8088)) # bind中绑定的是IP地址和端口号,注意是一个元组,就比如,将手机卡,插入了手机
server.listen(5) # 半连接池,最大等待连接数为5个,就比如开机
conn,address = server.accept() # 接听电话等着别人给你打电话

date = conn.recv(1024) # 听别人说话,接收1023个字节数
print(date)
date = conn.recv(1024) # 听别人说话,接收1023个字节数
print(date)


conn.close() # 挂断电话
server.close() # 关机

客户端:

import socket

client = socket.socket() #拿电话
client.connect(("127.0.0.1",8088)) #绑定的是IP地址和端口号,也是一个元组 拨号

client.send(b"hello") # 对别人发消息
client.send(b"hello") # 对别人发消息


client.close() # 挂电话

服务端打印结果:

b'hellohello'

这是因为tcp协议会将时间间隔短的,和文件大小小的会一次打包发送给对方

解决粘包问题:

struct模块:

import struct


print("--------------------------1--------------------------")
msg = "asdasdasdasdasd"
print("原字符串的长度")
print(len(msg))

handler = struct.pack("i",len(msg))
print("创建报头的长度")
print(len(handler))


res = struct.unpack("i",handler)[0]
print("解报头过后的长度")
print(res)





print("--------------------------2--------------------------")

msg1 = "asdasdasdasdasdasdasdasd"
print("原字符串的长度")
print(len(msg1))

handler1 = struct.pack("i",len(msg1))
print("创建报头的长度")
print(len(handler1))


res1 = struct.unpack("i",handler1)[0]
print("解报头过后的长度")
print(res1)

"""
--------------------------1--------------------------
原字符串的长度
15
创建报头的长度
4
解报头过后的长度
15
--------------------------2--------------------------
原字符串的长度
24
创建报头的长度
4
解报头过后的长度
24
"""

我们可以将报头发过去,然后解报头,就可以知道原来数据的大小,如果这个字节大小比我们接受的大,我们就可以一直让它接收,直到接收完成为止,

服务端:

import json
import os
import socket
import struct server_path = r'/Users/mac/Documents/client-server/server_movie' server = socket.socket() ip_port = ('127.0.0.1', 8080) server.bind(ip_port) server.listen(5) conn, addr = server.accept()
while 1: head_len = conn.recv(4) head_len = struct.unpack('i', head_len)[0] json_head = conn.recv(head_len).decode('utf-8') head = json.loads(json_head) file_size = head['file_size'] with open(os.path.join(server_path, head['file_name']), 'wb') as f:
while file_size:
if file_size >= 1024:
content = conn.recv(1024)
f.write(content)
file_size -= 1024
else:
content = conn.recv(file_size)
f.write(content)
break

客户端:

import os
import socket
import json
import struct client = socket.socket() ip_port = ('127.0.0.1', 8080) client.connect(ip_port) head = {
'file_path': r'/Users/mac/Documents/client-server/client_movie',
'file_name': None,
'file_size': None
}
movie_list = os.listdir(head['file_path']) while 1:
for i, m in enumerate(movie_list, 1):
print('%s --> %s' % (i, m))
choice = input('please input movie number:>>').strip()
if choice.isdigit():
choice = int(choice)
if choice in range(1, len(movie_list) + 1):
movie_name = movie_list[choice - 1]
head['file_name'] = movie_name
head['file_size'] = os.path.getsize(os.path.join(head['file_path'], head['file_name']))
json_head = json.dumps(head).encode('utf-8')
bytes_head = len(json_head)
pack_head = struct.pack('i', bytes_head)
client.send(pack_head)
client.send(json_head)
file_size = head['file_size']
with open(os.path.join(head['file_path'], head['file_name']), 'rb') as f:
while file_size:
if file_size >= 1024:
content = f.read(1024)
client.send(content)
file_size -= 1024
else:
content = f.read(file_size)
client.send(content)
print("finish")
break
else:
print('index out of range')
else:
print('input number...')

python基础--socket套接字、粘包问题的更多相关文章

  1. Python进阶----SOCKET套接字基础, 客户端与服务端通信, 执行远端命令.

    Python进阶----SOCKET套接字基础, 客户端与服务端通信, 执行远端命令. 一丶socket套接字 什么是socket套接字: ​ ​  ​ 专业理解: socket是应用层与TCP/IP ...

  2. python 29 Socket - 套接字

    目录 Socket - 套接字 Socket - 套接字 应用层与TCP/IP协议族通信层(或传输层)之间的抽象层,是一组接口()接收数据:当接口接收数据之后,交由操作系统: 如果数据与操作系统直接交 ...

  3. python开发socket套接字:粘包问题&udp套接字&socketserver

    一,发生粘包 服务器端 from socket import * phone=socket(AF_INET,SOCK_STREAM) #套接字 phone.setsockopt(SOL_SOCKET, ...

  4. 全网最详细python中socket套接字send与sendall的区别

    将数据发送到套接字. 套接字必须连接到远程套接字.  返回发送的字节数. 应用程序负责检查是否已发送所有数据; 如果仅传输了一些数据, 则应用程序需要尝试传递剩余数据.(需要用户自己完成) 将数据发送 ...

  5. python开发socket套接字:套接字&通信循环&链接循环&模拟远程命令

    一,套接字 先从服务器端说起.服务器端先初始化Socket,然后与端口绑定(bind),对端口进行监听(listen),调用accept阻塞,等待客户端连接.在这时如果有个客户端初始化一个Socket ...

  6. tcp套接字粘包解决办法

    粘包只会出现在tcp,udp传输不会产生粘包现象.解决粘包的原理就是服务器预先向客户端发送客户端即将获取文件的大小. 第一版解决方案: 服务器: # Author : Kelvin # Date : ...

  7. python TCP socket套接字编程以及注意事项

    TCPServer.py #coding:utf-8 import socket #s 等待链接 #c 实时通讯 s = socket.socket(socket.AF_INET,socket.SOC ...

  8. python基础--基于套接字进行文件传输、异常处理、socketserver模块

    异常处理: 什么是异常处理: 程序在运行过程中出现了不可预知的错误,并且该错误没有对应的处理机制,那么就会以异常的形式表现出来,造成的影响就是整个程序无法再正常运行 异常的结构: 异常的类型.异常的信 ...

  9. Python开发基础-Day23try异常处理、socket套接字基础1

    异常处理 错误 程序里的错误一般分为两种: 1.语法错误,这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正 2.逻辑错误,人为造成的错误,如数据类型错误.调用方法错误等,这些解 ...

随机推荐

  1. 19-10-30-C

    交文件吼啊. ZJ一下: T1是真·高中数学. T2不是很清楚,只得了30. T3打了一个欧拉序. 做的海星的地方: Vim太好用辣,直接按平常打叫上去它就是 freopen T1仔仔细细的研究了高考 ...

  2. 表单修饰符.lazy.number.trim

    <!DOCTYPE html> <html lang="zh"> <head> <title></title> < ...

  3. Python学习day13-函数进阶(1)

    Python学习day13-函数进阶(1) 闭包函数 闭包函数,从名字理解,闭即是关闭,也就是说把一个函数整个包起来.正规点说就是指函数内部的函数对外部作用域而非全局作用域的引用. 为函数传参的方式有 ...

  4. HDU--2639 Bone Collector II(01背包)

    题目http://acm.hdu.edu.cn/showproblem.php?pid=2639 分析:这是求第K大的01背包问题,很经典.dp[j][k]为背包里面装j容量时候的第K大的价值. 从普 ...

  5. Aspose破解版本dll

    下面是Aspose破解版本dll,并不是最新版本,有需要的可以下载使用: 下载Aspose各种破解版dll

  6. 06-6-es6模板字符串

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. 廖雪峰Java10加密与安全-2加密算法-2Base64编码

    1.Base64编码 Base64一种把二进制数据用文本表示的编码算法.例如 中有3个字节{\xe4, \xb8, \xad},一共是24位,每6位分组,变成4个字节{39, 0b, 22, 2d}, ...

  8. 子类A继承父类B, A a = new A(); 则父类B构造函数、父类B静态代码块、父类B非静态代码块、子类A构造函数、子类A静态代码块、子类A非静态代码块 执行的先后顺序是

    按照先后顺序: 1,静态先于非静态代码库执行(静态代码块随着类的加载而加载,初始化只执行一次) 2,父类先于子类 3,非静态代码块优于构造函数执行 所以执行顺序如下: 父类B静态代码块->子类A ...

  9. 关于MySQL IN LIKE OR使用索引的问题

    以前在网上看了一些资料,有些人说话不严谨,导致一直被误导,最近在实际开发中发现一些结论有问题,因此特地整理了一下,防止下次继续犯错. 以下前提是有对这个字段建立索引(简直废话,没建的肯定不会使用索引啊 ...

  10. R语言之数据处理

    R语言之数据处理 一.向量处理 1.选择和显示向量 data[1] data[3] data[1:3] data[-1]:除第一项以外的所有项 data[c(1,3,4,6)] data[data&g ...