python套接字编程实现ntp服务和远程命令执行

目录

基于udp实现ntp服务
基于tcp实现远程命令执行
基于udp实现远程命令执行
tcp与udp的比较

  

前面关于套接字基础请查阅

https://www.cnblogs.com/-wenli/p/10173888.html

基于udp实现ntp服务

服务端

import time
from socket import * def main():
ip_port = ('127.0.0.1', 4444)
buffer_size = 1024 s1 = socket(AF_INET,SOCK_DGRAM) #数据报
s1.bind(ip_port) while True:
data,addr= s1.recvfrom(buffer_size)
if not data:
fmt = '%Y-%m-%d %X' #udp服务可以接收空信息,如果为空信息,则为默认格式
else:
fmt = '%'+data.decode('utf-8') #自定义格式 back_time=time.strftime(fmt)
s1.sendto(back_time.encode('utf-8'),addr) if __name__ =='__main__':
main()

客户端

from socket import *

def main():
ip_port = ('127.0.0.1', 4444)
buffer_size = 1024 s2 = socket(AF_INET,SOCK_DGRAM) #数据报
print('请输入回车获取当前完整时间,Y获取当前年份,m获取当前月份,,d获取当前日期,X获取当前时间')
while True:
data = input('-->:')
s2.sendto(data.encode('utf--8'),ip_port) #udp发信息没有链接,所以每一个发送信息都需要指定ip和端口 data1,addr=s2.recvfrom(buffer_size) print('标准时间:',data1.decode('utf-8')) if __name__ =='__main__':
main()

  

运行结果

基于tcp实现远程执行命令

服务端

from socket import  *
import subprocess def main():
ip_port=('127.0.0.1',8080)
back_log=5
buffer_size=1024 s1 = socket(AF_INET,SOCK_STREAM)
s1.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
s1.bind(ip_port)
s1.listen(back_log) while True:
conn,addr=s1.accept() while True:
try:
#收信息
cmd = conn.recv(buffer_size)
if not cmd:break
print('收到的命令是:',cmd.decode('utf-8')) #执行命令
res = subprocess.Popen(cmd.decode('utf-8'),shell=True,
stderr=subprocess.PIPE,
stdout=subprocess.PIPE,
stdin=subprocess.PIPE) err = res.stderr.read()
if err:
cmd_res=err
else:
cmd_res=res.stdout.read() #发信息
#注意:执行的结果默认jbk编码方式,所以客户端必须使用gbk方式解码
conn.send(cmd_res) except Exception:
break
conn.close()
s1.close() # 关闭服务端套接字 if __name__ == '__main__':
main()

  

客户端

from socket import  *

def main():
ip_port=('127.0.0.1',8080)
buffer_size=2048 s1 = socket(AF_INET,SOCK_STREAM)
s1.connect(ip_port) while True:
cmd = input('-->')
if not cmd:continue
if cmd =='quite':break
s1.send(cmd.encode('utf-8')) reponse = s1.recv(buffer_size)
print('命令执行结果:',reponse.decode('gbk')) s1.close() if __name__=='__main__':
main()

  

补充知识

补充: 你从管道中读取输出,只能读取一次,输出到屏幕,管道里面的数据就会取出来
res=subprocess.Popen('dir',shell=True,stdout=subprocess.PIPE) 第一个参数为命令,第二个参数为shell=Ture,意思是使用shell作为命令解释器去解释前面的命令,后面是重定向标准输入和标准输出以及错误输出
(默认输出到屏幕)
res.stdout.read()  从管道读取结果
res.stderr.read() 从管道读取错误
res.stdin.read() 从管道读取输入 这个程序解决两个问题:
客户端正常断开连接,在服务端加上if not cmd:break,判断接收信息为空就结束接收信息的循环,继续等待下一次连接,正常情况,服务端不会接收到空。
客户毒案异常中断,在服务端上加上异常处理

运行结果

基于udp实现远程执行命令

服务端

from socket import *

import subprocess

def main():
ip_port = ('127.0.0.1', 9003) bufsize = 1024 udp_server = socket(AF_INET, SOCK_DGRAM) udp_server.bind(ip_port) while True:
try:
# 收消息 cmd, addr = udp_server.recvfrom(bufsize) print('用户命令----->', cmd.decode('utf-8')) # 逻辑处理 res = subprocess.Popen(cmd.decode('utf-8'), shell=True,
stderr=subprocess.PIPE,
stdout=subprocess.PIPE,
stdin=subprocess.PIPE) err = res.stderr.read()
if err:
cmd_res = err
else:
cmd_res = res.stdout.read()
if not cmd_res:
cmd_res = '执行成功'.encode('gbk') # 发信息
# 注意:执行的结果默认jbk编码方式,所以客户端必须使用gbk方式解码
udp_server.sendto(cmd_res,addr)
except Exception:
break if __name__=='__main__':
main()

  

客户端

from socket import *

def main():
ip_port=('127.0.0.1',9003) buffer_size=1024
udp_client=socket(AF_INET,SOCK_DGRAM) while True:
cmd = input('-->')
if not cmd: continue
if cmd == 'quite': break
udp_client.sendto(cmd.encode('utf-8'),ip_port)
reponse,addr = udp_client.recvfrom(buffer_size)
print('命令执行结果:', reponse.decode('gbk'))
udp_client.close() if __name__=='__main__':
main()

  

运行结果

tcp与udp的比较

tcp基于链接通信

基于链接,则需要listen(backlog),指定连接池的大小
基于链接,必须先运行的服务端,然后客户端发起链接请求
对于mac系统:如果一端断开了链接,那另外一端的链接也跟着完蛋recv将不会阻塞,收到的是空(解决方法是:服务端在收消息后加上if判断,空消息就break掉通信循环)
对于windows/linux系统:如果一端断开了链接,那另外一端的链接也跟着完蛋recv将不会阻塞,收到的是空(解决方法是:服务端通信循环内加异常处理,捕捉到异常后就break掉通讯循环)
udp无链接 无链接,因而无需listen(backlog),更加没有什么连接池之说了
无链接,udp的sendinto不用管是否有一个正在运行的服务端,可以己端一个劲的发消息,只不过数据丢失
recvfrom收的数据小于sendinto发送的数据时,在mac和linux系统上数据直接丢失,在windows系统上发送的比接收的大直接报错
只有sendinto发送数据没有recvfrom收数据,数据丢失

  

python套接字编程实现ntp服务和远程命令执行的更多相关文章

  1. python套接字编程基础

    python套接字编程 目录 socket是什么 套接字的工作流程 基于tcp的套接字 基于udp的套接字 socket是什么 客户端/服务器架构(C/S架构) 服务端:提供服务的一端 客户端:请求服 ...

  2. Python套接字编程(1)——socket模块与套接字编程

    在Python网络编程系列,我们主要学习以下内容: 1. socket模块与基本套接字编程 2. socket模块的其他网络编程功能 3. SocketServer模块与简单并发服务器 4. 异步编程 ...

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

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

  4. 入门级:怎么使用C#进行套接字编程(二)

    入门级:怎么使用C#进行套接字编程(一) 原文地址如下: C# Server Socket program C# Client Socket program 代码环境:VS2010+Win8.1企业评 ...

  5. Python黑帽编程2.8 套接字编程

    Python黑帽编程2.8 套接字编程 套接字编程在本系列教程中地位并不是很突出,但是我们观察网络应用,绝大多数都是基于Socket来做的,哪怕是绝大多数的木马程序也是如此.官方关于socket编程的 ...

  6. 【Python网络编程】利用Python进行TCP、UDP套接字编程

    之前实现了Java版本的TCP和UDP套接字编程的例子,于是决定结合Python的学习做一个Python版本的套接字编程实验. 流程如下: 1.一台客户机从其标准输入(键盘)读入一行字符,并通过其套接 ...

  7. UDP,TCP的套接字编程的Python实现

    UDP,TCP的套接字编程的Python实现 套接字:连接应用层和运输层,应用层的网络应用程序使用IP地址+端口号来标识自己,然后通过套接字调用运输层为其服务,网络应用程序只能指定自己要使用的网络类型 ...

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

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

  9. Python 3中套接字编程中遇到TypeError: 'str' does not support the buffer interface的解决办法

    转自:http://blog.csdn.net/chuanchuan608/article/details/17915959 目前正在学习python,使用的工具为python3.2.3.发现3x版本 ...

随机推荐

  1. MySQL中查询行数最多的表并且排序

    #切换到schema use information_schema; #查询数据量最大的30张表 并排序 select table_name,table_rows from tables order ...

  2. MySQL自动设置create_time和update_time

    参考表结构 CREATE TABLE `t_baby` ( `baby_id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) NOT NULL, ...

  3. 【逆向工具】IDA使用5-( string、图形化与视图的切换、图形化显示反汇编地址、自动注释、标签使用)

    分析petya病毒时新学会的技巧. IDA技巧1 : string 提取文件中的字符串内容,如果看到一些文件字符串可以定位到关键的函数中. view -> open subview -> ...

  4. 【转】Python之文件读写

    [转]Python之文件读写 本节内容: I/O操作概述 文件读写实现原理与操作步骤 文件打开模式 Python文件操作步骤示例 Python文件读取相关方法 文件读写与字符编码 一.I/O操作概述 ...

  5. SciPy模块应用

    1.图像模糊  图像的高斯模糊是非常经典的图像卷积例子.本质上,图像模糊就是将(灰度)图像I 和一个高斯核进行卷积操作:,其中是标准差为σ的二维高斯核.高斯模糊通常是其他图像处理操作的一部分,比如图像 ...

  6. 深入解析内存原理:SRAM的基本原理

    1. SRAM芯片的引脚定义早期的SRAM 芯片采用了20 线双列直插(DIP:Dual Inline Package)封装技术,它们之所以具有这么多的针脚,是因为它们必须:• 每个地址信号都需要一根 ...

  7. shell编程之helloworld

    /bin/sh与/bin/bash的区别sh:如果前面有语句报错,则报错语句后面的命令不执行bash:如果前面有语句报错,后面的命令也会执行sh跟bash的区别,实际上就是bash有没有开启posix ...

  8. SQL定义变量

  9. 恋爱Linux(Fedora20)1——安装开启ssh服务

    1) 安装openssh-server # yum install openssh-server 2) 查看是否已成功安装openssh-server # rpm -qa | grep openssh ...

  10. Myeclipse10.7安装git插件并将Java项目上传到码云(github)

    注:本文来源:外匹夫的<Myeclipse10.7安装git插件并将Java项目上传到码云(github)> 一.先说说安装egit插件的步骤(安装egit不成功的原因主要是下载的egit ...