from socket import *

#以下是关于tcp:服务端 和 客户端的小例子#服务端socket_server = socket(AF_INET, SOCK_STREAM)

socket_server.bind(('127.0.0.1', 8080))print('进行监听')socket_server.listen(5)

while True:    print('进行连接')    conn, address = socket_server.accept()    print('连接成功')

    while True:        data=conn.recv(1024)        if not len(data):break        conn.send(data.upper())        print(data.decode(encoding='utf-8'))        conn.close()

socket_server.close()

from socket import *import struct

socket_client = socket(AF_INET, SOCK_STREAM)print('进行连接')socket_client.connect(('127.0.0.1', 8080))print('连接成功')while True:    msg = input('请输入')    if not len(msg): continue    socket_client.send(msg.encode(encoding='utf-8'))    data =socket_client.recv(1024)    print(data.decode(encoding='utf-8'))

socket_client.close()

#远程执行命令的小例子#服务端import socketimport osimport subprocessphone = socket.socket(socket.AF_INET, socket.SOCK_STREAM)print('进行绑定,监听')phone.bind(('127.0.0.1', 8080))phone.listen(5)

def cmd(cmdlist):    obj=subprocess.Popen(    cmdlist,    shell=True,    stdout=subprocess.PIPE,    stderr=subprocess.PIPE    )

    stdout_res=obj.stdout.read()    stderr_res=obj.stderr.read()

    return stdout_res+stderr_res#假如不写成方法,这里可以分成两次发送过去,更加节省内存

while True:    conn, add = phone.accept()    print('建立连接')

    while True:        try:            msg = conn.recv(1024)            if not len(msg):                break

            print('执行命令')            print(msg)            #os.system(msg.decode(encoding='utf-8'))

            stdout_res=cmd(msg.decode(encoding='utf-8'))            print('发送消息')            conn.send(stdout_res)        except Exception:            break

    conn.close()phone.close()

#客户端import socketst = socket.socket(socket.AF_INET, socket.SOCK_STREAM)st.connect(('127.0.0.1', 8080))while True:    msg=input('请输入cmd 命令').strip()    print('发送消息')    if not len(msg):continue

    st.send(msg.encode(encoding='utf-8'))    data=st.recv(1024)    print(data.decode('gbk'))

st.close()

#获取服务端内容小例子

from socket import *import structimport subprocessimport json

st = socket(AF_INET, SOCK_STREAM)print('绑定并且监听')st.bind(('127.0.0.1', 8080))st.listen(5)print('绑定监听成功')

while True:    conn, _ = st.accept()    print('与客户端建立连接成功')

    while True:        try:            cmd = conn.recv(1024)            if not len(cmd): break            cmd = cmd.decode(encoding='utf-8')            if cmd != 'get':                obj_sub = subprocess.Popen(cmd,                                           shell=True,                                           stderr=subprocess.PIPE,                                           stdout=subprocess.PIPE)                sub_out = obj_sub.stdout.read()                sub_err = obj_sub.stderr.read()

                total_size = len(sub_err) + len(sub_out)                file_path = '为空'            else:                file_path = 'get.txt'                import os

                total_size = os.path.getsize(file_path)

            header_dic = {                'file_name': file_path,                'total_size': total_size,                'hashlib': '还没有有开始写呢'            }

            header_json = json.dumps(header_dic)            header_bytes = header_json.encode(encoding='utf-8')

            conn.send(struct.pack('i', len(header_bytes)))  # 将文件头的长度发送给客户端

            conn.send(header_bytes)  # 将文件头的内容发给客户端            if cmd == 'get':                with open(file_path, 'rb') as f:

                    for line in f:                        conn.send(line)            else:                conn.send(sub_out)  # 正常内容                conn.send(sub_err)  # 错误消息

        except ConnectionResetError:            break

conn.close()

st.close()
from socket import *import structimport subprocessimport json

st = socket(AF_INET, SOCK_STREAM)st.connect(('127.0.0.1', 8080))

print('与客户端建立连接')

while True:    msg = input('请输入cmd命令:').strip()    if not len(msg):        continue    st.send(msg.encode(encoding='utf-8'))

    header_struct_len = st.recv(4)

    header_len = (struct.unpack('i', header_struct_len))[0]

    header_json_dic = st.recv(header_len)  # 拿到文件头    header_dic = header_json_dic.decode(encoding='utf-8')    header_dic = json.loads(header_dic)    print(header_dic)    res = b''    while header_dic['total_size'] > 0:        data = st.recv(1024)        header_dic['total_size'] -= len(data)        res += data        # print(data.decode(encoding='gbk'))    print('msg')    if msg == 'get':        print(res.decode(encoding='utf-8'))        #print(res)        print(type(res))

    else:        print(res.decode(encoding='gbk'))

st.close()print('error')

python tcp 粘包问题解决、文件下载等的更多相关文章

  1. python套接字解决tcp粘包问题

    python套接字解决tcp粘包问题 目录 什么是粘包 演示粘包现象 解决粘包 实际应用 什么是粘包 首先只有tcp有粘包现象,udp没有粘包 socket收发消息的原理 发送端可以是一K一K地发送数 ...

  2. Python全栈-网络编程-TCP粘包

    一.什么是TCP粘包 C/S架构下,接收方不知道每个消息的发送间隙.也不知道每次应该提取多少个字节的数据,与此同时,TCP是面向连接的,面向流的,收发两端都要有,因此发送端为了将多个发往接收端的数据包 ...

  3. netty之==TCP粘包/拆包问题解决之道(一)

    一.TCP粘包/拆包是什么 TCP是一个“流”协议,所谓流,就是没有界限的一长串二进制数据.TCP作为传输层协议并不不了解上层业务数据的具体含义,它会根据TCP缓冲区的实际情况进行数据包的划分,所以在 ...

  4. 百万年薪python之路 -- socket粘包问题解决

    socket粘包问题解决 1. 高大上版解决粘包方式(自定制包头) 整体的流程解释 整个流程的大致解释: 我们可以把报头做成字典,字典里包含将要发送的真实数据的描述信息(大小啊之类的),然后json序 ...

  5. Mina框架断包、粘包问题解决方式

    Mina框架断包.粘包问题解决方式 Apache Mina Server 是一个网络通信应用框架,也就是说,它主要是对基于TCP/IP.UDP/IP协议栈的通信框架(当然.也能够提供JAVA 对象的序 ...

  6. c#解决TCP“粘包”问题

    一:TCP粘包产生的原理 1,TCP粘包是指发送方发送的若干包数据到接收方接收时粘成一包,从接收缓冲区看,后一包数据的头紧接着前一包数据的尾.出现粘包现象的原因是多方面的,它既可能由发送方造成,也可能 ...

  7. 6行代码解决golang TCP粘包

    转自:https://studygolang.com/articles/12483 什么是TCP粘包问题以及为什么会产生TCP粘包,本文不加讨论.本文使用golang的bufio.Scanner来实现 ...

  8. golang 解决 TCP 粘包问题

    什么是 TCP 粘包问题以及为什么会产生 TCP 粘包,本文不加讨论.本文使用 golang 的 bufio.Scanner 来实现自定义协议解包. 协议数据包定义 本文模拟一个日志服务器,该服务器接 ...

  9. Golang Tcp粘包处理(转)

    在用golang开发人工客服系统的时候碰到了粘包问题,那么什么是粘包呢?例如我们和客户端约定数据交互格式是一个json格式的字符串: {"Id":1,"Name" ...

随机推荐

  1. 30种提高mysql处理速度的方法

    1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 2.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉 ...

  2. tensorflow serving 中 No module named tensorflow_serving.apis,找不到predict_pb2问题

    最近在学习tensorflow serving,但是运行官网例子,不使用bazel时,发现运行mnist_client.py的时候出错, 在api文件中也没找到predict_pb2,因此,后面在网上 ...

  3. 03_java基础(四)之方法的创建与调用

    import org.junit.Test; public class Main { public static void main(String[] args) { System.out.print ...

  4. Android Studio 统计行数

    开发中常常会想看看自己累积在这个项目中写了多少代码了,以下就是在Android Studio查看统计项目代码总行数的方法. 打开Android Studio,按快捷键Ctrl+Shift+A 输入fi ...

  5. PO ITEM_BOM_工艺路线SQL

    ---物料主数据接口 SELECT count(*)PO_MARA FROM STG.PO_MARA; SELECT count(*)PO_MARC FROM STG.PO_MARC; SELECT ...

  6. javascript 执行环境,作用域、作用域链、闭包

    1.执行环境 执行环境是JavaScript中国最为重要的一个概念.执行环境定义了变量或函数有权访问的其他数据,决定了他们各自的行为.每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量和函数 ...

  7. JMeter学习(四)参数化(转载)

    转载自 http://www.cnblogs.com/yangxia-test JMeter也有像LR中的参数化,本篇就来介绍下JMeter的参数化如何去实现. 参数化:录制脚本中有登录操作,需要输入 ...

  8. PHPActiveRecord 学习三

    #事务处理 注意事务 数据库要用InnoDB引擎 $c1 = User::connection(); try { //开启事务 $c1->transaction(); //sql语句 $sql ...

  9. JS 7路线图

    JS 7路线图 今天,我很高兴宣布路线图到视频.JS 7!虽然这是一个主要版本更新,但很少有真正打破.两个主要变化是添加了videojs-http-streaming,简称为VHS,以及删除了对较老版 ...

  10. vue table中使用多选的问题(翻页后如何保存已选项),联动echarts图表实现流量监控

    流量监控项目需求: 根据表格数据,添加多选功能,默认全选,根据已选项更新图表视图 1.表格需要多选 2.要联动图表,所以关键是要利用表格多选的触发回调函数 vue table中使用多选: 很简单,只需 ...