Python socket套接字实现CS模式远程命令执行功能案例

2018-09-22 00:47

阅读:748

  本文实例讲述了Python socket套接字实现C/S模式远程命令执行功能。分享给大家供大家参考,具体如下:

   一. 前言

  要求:

  使用python的socket套接字编写服务器/客户机模式的远程命令执行脚本。

  serverCmd.py 远程机器上用来执行客户端发送命令的脚本
clientCmd.py 本地机器上,向远程服务器发送命令的脚本
servers.txt 本地机器上,存放所有的远程服务器IP地址文件(仅支持第一个IP)

  发送:cmd [command]形式消息,让远程主机执行命令(本地主机无回显)

  发送:close session消息,双方关闭会话。

   二. 源码

  下载地址: 点击此处本站下载。

  注:

  1. 代码注释较少,建议有一定套接字编程基础。
2. 或者直接简单部分修改IP使用。
3. clientCmd.py和servers.txt(修改IP地址后)放在同一目录。
4.程序为简单Demo,仅为学习记录。

  serverCmd.py

  clientCmd.py

  servers.txt

  # server ip list
192.168.0.139

   三. 运行效果

  python serverCmd.py

  [+] Server is running on port:47091 at 20161013 17:50:19
[+] Connect success -> (192.168.0.241, 4255) at 20161013 17:50:32
[+] Receive:hello
[+] Receive:你好
[+] Receive:cmd ip
ip 不是内部或外部命令,也不是可运行的程序
或批处理文件。

  [+] Receive:cmd ipconfig

  Windows IP 配置

  以太网适配器 本地连接:

   连接特定的 DNS 后缀 . . . . . . . :
本地链接 IPv6 地址. . . . . . . . : ****::****:****:****:*******
IPv4 地址 . . . . . . . . . . . . : 192.168.0.139
子网掩码 . . . . . . . . . . . . : 255.255.255.0
默认网关. . . . . . . . . . . . . : 192.168.0.1

  隧道适配器 isatap.{****-6122-4F83-8828-****}:

   媒体状态 . . . . . . . . . . . . : 媒体已断开
连接特定的 DNS 后缀 . . . . . . . :

  [+] Receive:cmd ping

  正在 Ping 具有 32 字节的数据:
来自 180.97.33.108 的回复: 字节=32 时间=66ms TTL=36
来自 180.97.33.108 的回复: 字节=32 时间=66ms TTL=36
来自 180.97.33.108 的回复: 字节=32 时间=64ms TTL=36
来自 180.97.33.108 的回复: 字节=32 时间=65ms TTL=36

  180.97.33.108 的 Ping 统计信息:
数据包: 已发送 = 4,已接收 = 4,丢失 = 0 (0% 丢失),
往返行程的估计时间(以毫秒为单位):
最短 = 64ms,最长 = 66ms,平均 = 65ms

  [+] Receive:要结束了
[+] Receive:close session
[+] Quit success

  python clientCmd.py

  [*] Please input command:
hello
[+] Send 192.168.0.139:47091 -> hello
[+] Receive :[Server]success

  [*] Please input command:
你好
[+] Send 192.168.0.139:47091 -> 你好
[+] Receive :[Server]success

  [*] Please input command:
cmd ip
[+] Send 192.168.0.139:47091 -> cmd ip
[+] Receive :[Server]success

  [*] Please input command:
cmd ipconfig
[+] Send 192.168.0.139:47091 -> cmd ipconfig
[+] Receive :[Server]success

  [*] Please input command:
cmd ping
[+] Send 192.168.0.139:47091 -> cmd ping
[+] Receive :[Server]success

  [*] Please input command:
要结束了
[+] Send 192.168.0.139:47091 -> 要结束了
[+] Receive :[Server]success

  [*] Please input command:
close session
[+] Send 192.168.0.139:47091 -> close session
[+] Receive :[Server]success

  更多关于Python相关内容可查看本站专题:《Python Socket编程技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

  希望本文所述对大家Python程序设计有所帮助。


评论


亲,登录后才可以留言!