远程执行命令

先来学习一个新模块 , 一会用到的..

  1. 新模块: subprocess
  2. 执行系统命令
  3. r = subprocess.Popen('ls',shell=True,stdout=subprocess.PIPE,
  4. stderr=subprocess.PIPE)
  5. subprocess.Popen(a,b,c,d)
  6. a: 要执行的系统命令(str)
  7. b: shell = True 表示确定我当前执行的命令为系统命令
  8. c: 表示正确信息的输出管道
  9. d: 表示错误信息的输出管道

下边直接上代码,一看就懂.  TCP的

  1. import socket
  2. import subprocess
  3. sk = socket.socket()
  4. sk.bind(('127.0.0.1',9090))
  5. sk.listen()
  6. conn,addr = sk.accept()
  7. while 1:
  8. cmd = conn.recv(1024).decode('utf-8')
  9. res = subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE,
  10. stderr=subprocess.PIPE)
  11. std_out = res.stdout.read()# 读取正确的返回信息
  12. std_err = res.stderr.read()# 读取错误的返回信息
  13.  
  14. if std_out:
  15. conn.send(std_out)
  16. else:
  17. conn.send(std_err)
  18.  
  19. conn.close()
  20. sk.close()

远程服务端

  1. import socket
  2. sk = socket.socket()
  3. sk.connect_ex(('127.0.0.1',9090))
  4. while 1:
  5. cmd = input('请输入一个命令>>>')
  6. sk.send(cmd.encode('utf-8'))
  7. print(sk.recv(204800000).decode('gbk'))
  8.  
  9. sk.close()

远程客户端

就是引用了一个模块的功能,其他的还是简单的收发功能.

  1. res=subprocess.Popen(cmd.decode('utf-8'),
  2. shell=True,
  3. stderr=subprocess.PIPE,
  4. stdout=subprocess.PIPE)
  5.  
  6. 的结果的编码是以当前所在的系统为准的,如果是windows,那么res.stdout.read()读出的就是GBK编码的,在接收端需要用GBK解码
  7.  
  8. 且只能从管道里读一次结果
  9.  
  10. 注意

--------------------粘包---------------------------

 UDP不会发生黏包--------

  1. UDPuser datagram protocol,用户数据报协议)是无连接的,面向消息的,提供高效率服务。
  2. 不会使用块的合并优化算法,, 由于UDP支持的是一对多的模式,所以接收端的skbuff(套接字缓冲区)采用了链式结构来记录每一个到达的UDP包,
    在每个UDP包中就有了消息头(消息来源地址,端口等信息),这样,对于接收端来说,就容易进行区分处理了。
    即面向消息的通信是有消息保护边界的。
  3. 对于空消息:tcp是基于数据流的,于是收发的消息不能为空,这就需要在客户端和服务端都添加空消息的处理机制,防止程序卡住,
    udp是基于数据报的,即便是你输入的是空内容(直接回车),也可以被发送,udp协议会帮你封装上消息头发送过去。
  4. 不可靠不黏包的udp协议:udprecvfrom是阻塞的,一个recvfrom(x)必须对唯一一个sendinto(y),收完了x个字节的数据就算完成,若是y;x数据就丢失,
    这意味着udp根本不会粘包,但是会丢数据,不可靠。

补充说明:

  1. UDP协议发送时,用sendto函数最大能发送数据的长度为:65535- IP头(20) UDP头(8)=65507字节。
    sendto函数发送数据时,如果发送数据长度大于该值,则函数会返回错误。(丢弃这个包,不进行发送)
  2.  
  3. TCP协议发送时,由于TCP是数据流协议,因此不存在包大小的限制(暂不考虑缓冲区的大小),这是指在用send函数时,数据长度参数不受限制。
    而实际上,所指定的这段数据并不一定会一次性发送出去,如果这段数据比较长,会被分段发送,如果比较短,可能会等待和下一次数据一起发送。

总结

黏包现象只发生在tcp协议中:

1.从表面上看,黏包问题主要是因为发送方和接收方的缓存机制、tcp协议面向流通信的特点。

2.实际上,主要还是因为接收方不知道消息之间的界限,不知道一次性提取多少字节的数据所造成的

解决方案------------

我们可以借助一个模块,这个模块可以把要发送的数据长度转换成固定长度的字节。这样客户端每次接收消息之前只要先接受这个固定长度字节的内容看一看接下来要接收的信息大小,那么最终接受的数据只要达到这个值就停止,就能刚好不多不少的接收完整的数据了。

文件上传解决粘包 的代码:  利用字典先传过去文件大小即可....

  1. import socket
  2. import json
  3. import struct
  4. sk = socket.socket()
  5. sk.bind(('127.0.0.1',9090))
  6. sk.listen()
  7. conn,addr = sk.accept()
  8. dic_size = conn.recv(4)# 先接受4字节长度的一个bytes, 代表字典的大小
  9. dic_size = struct.unpack('i',dic_size)[0]# 将这个特殊的bytes转变成原数字
  10. dic_str = conn.recv(dic_size).decode('utf-8')# 根据字典大小去获取字典,以免和底下获取文件内容发生粘包
  11. dic = json.loads(dic_str)# 反序列化 得到字典 opt filename filesize
  12. if dic['opt'] == 'upload':
  13. '''接收文件'''
  14. filename = ''+dic['filename']# 将文件名字修改,防止重名
  15. with open(filename,'wb') as f:
  16. while dic['filesize']:
  17. content = conn.recv(1024)
  18. f.write(content)
  19. dic['filesize'] -= len(content)
  20. elif dic['opt'] == 'download':
  21. '''给客户端传输文件'''
  22. conn.close()
  23. sk.close()

文件上传 服务端

  1. import socket
  2. import os
  3. import json
  4.  
  5. import struct
  6.  
  7. sk = socket.socket()
  8. sk.connect(('127.0.0.1',9090))
  9. l = ['upload','download']
  10. for i,v in enumerate(l):
  11. print(i+1,v)
  12. dic = {'opt':None,'filename':None,'filesize':None}
  13. while 1:
  14. opt = input("请输入功能选项>>>")# 客户要执行的操作选项
  15. if opt == '':
  16. '''upload'''
  17. file_dir = input('请输入文件路径>>>')# 'E:/sylar/python_workspace/day34/作业/时间同步机制_client.py'
  18. file_name = os.path.basename(file_dir)# 获取文件名字
  19. file_size = os.path.getsize(file_dir)# 获取文件大小
  20. dic['opt'] = l[int(opt)-1]
  21. dic['filename'] = file_name
  22. dic['filesize'] = file_size
  23. dic_str = json.dumps(dic)# 将字典序列化成一个字符串形式的字典
  24. dic_size = len(dic_str)# 获取字典的大小
  25. ds = struct.pack('i',dic_size)# 把一个小于21.3E的一个数字转变成一个4字节长度的bytes
  26. sk.send(ds + dic_str.encode('utf-8'))# 发送给服务器
  27. with open(file_dir,'rb') as f:
  28. while file_size:
  29. content = f.read(1024)# 文件内容
  30. sk.send(content)
  31. file_size -= len(content)
  32. elif opt == '':
  33. '''download'''
  34. pass
  35. else:
  36. print('有误')
  37.  
  38. sk.close()

文件上传 客户端

收发概括

python 网络编程(远程执行命令与粘包)的更多相关文章

  1. 网络编程之模拟ssh远程执行命令、粘包问题 、解决粘包问题

    目录 模拟ssh远程执行命令 服务端 客户端 粘包问题 什么是粘包 TCP发送数据的四种情况 粘包的两种情况 解决粘包问题 struct模块 解决粘包问题 服务端 客户端 模拟ssh远程执行命令 服务 ...

  2. Python_编写UDP通信编解码类、文件的上传、远程执行命令、黏包

    1.UDP通信编解码类 (1) 类 # ------------------UDP通信解码编码类------------------------ from socket import * class ...

  3. python之paramiko 远程执行命令

    有时会需要在远程的机器上执行一个命令,并获得其返回结果.对于这种情况,python 可以很容易的实现. 1 .工具 Python paramiko 1) Paramiko模块安装 在Linux的Ter ...

  4. Python 简单的远程执行命令

    client端执行命令,server端返回命令结果 # server 端 import socket, subprocess sk = socket.socket() address=('127.0. ...

  5. python实现批量远程执行命令及批量上传下载文件

    #!/usr/bin/env python # -*- coding: utf- -*- # @Time : // : # @Author : xuxuedong # @Site : # @File ...

  6. 【游戏开发】网络编程之浅谈TCP粘包、拆包问题及其解决方案

    引子 现如今手游开发中网络编程是必不可少的重要一环,如果使用的是TCP协议的话,那么不可避免的就会遇见TCP粘包和拆包的问题,马三觉得haifeiWu博主的 TCP 粘包问题浅析及其解决方案 这篇博客 ...

  7. TCP 远程执行CMD (解决粘包问题) 代码

    服务端 from socket import * import subprocess,json,struct server= socket(AF_INET,SOCK_STREAM) server.bi ...

  8. Python网络编程基础 struct模块 解决黏包问题 FTP

    struct模块 解决黏包问题 FTP

  9. 网络编程socket模块subprocess模块 粘包的解决

    什么是socket? tcp 可靠地面向连接协议 udp 不可靠的,无连接的服务,传送效率高

随机推荐

  1. FastJSON、Gson、Jackson(简单了解使用)

    下载地址(maven) Jackson:http://mvnrepository.com/search?q=jackson FastJson:http://mvnrepository.com/sear ...

  2. 大专生自学web前端前前后后

    先做个自我介绍,我13年考上一所很烂专科民办的学校,学的是生物专业,具体的学校名称我就不说出来献丑了.13年我就辍学了,我在那样的学校,一年学费要1万多,但是根本没有人学习,我实在看不到希望,我就退学 ...

  3. SpringBoot非官方教程 | 第十一篇:springboot集成swagger2,构建优雅的Restful API

    转载请标明出处: 原文首发于:https://www.fangzhipeng.com/springboot/2017/07/11/springboot-swagger2/ 本文出自方志朋的博客 swa ...

  4. linux下ssh/sftp配置和权限设置

    基于 ssh 的 sftp 服务相比 ftp 有更好的安全性(非明文帐号密码传输)和方便的权限管理(限制用户的活动目录). 1.开通 sftp 帐号,使用户只能 sftp 操作文件, 而不能 ssh ...

  5. Java解决跨域问题

    同源 URL由协议, 域名, 端口组成. 如果两个URL的协议, 域名, 端口相同, 那么这两个URL为同源. 同源策略 script, iframe, link 可以跨域加载一些静态资源, 比如脚本 ...

  6. 【TOJ 4493】Remove Digits(单调栈贪心)

    描述 Given an N-digit number, you should remove K digits and make the new integer as large as possible ...

  7. 洛谷P2052 [NOI2011]道路修建(树形DP)

    题目描述 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家 之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿 意修建恰好 n – 1 条双向道路. 每条道 ...

  8. DOM查询

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

  9. 路由器基础设置之ospf

    我们将以上面的拓扑图来进行实验,要用ospf的协议达到全网互通的效果 router1: enable 进入特权模式 config t 进入全局配置模式 interface L0 ip address ...

  10. 富文本编辑器 wangEditor.js

    1.引用 wangEditor 相关js  和 css 下载地址:https://files.cnblogs.com/files/kitty-blog/WangEditor.zip 3.页面: < ...