#通过socket 实现简单的ssh#服务端

 #服务端
import os
import socket server = socket.socket() #server.bind(('0.0.0.0',9999))
server.bind(('localhost',9999))
server.alisten() while True:
conn,addr = server.accept()
print ('new conn:',addr)
while True:
print ('等待新指令')
data = conn.recv(1024)
if not data:
print ('客户端已经断开')
break print ('执行指令:',data)
cmd_res = os.poen(data.decode()).read()#接收字符串,执行结果也是字符串
print('before send',len(cmd_res))
if len(cmd_res) == 0 :
cmd_res = 'cmd has no output...' conn.send(str(len(cmd_res.encode())).encode('utf-8')) #先发文件大小给客户端
conn.send(cmd_res.encode('utf-8'))
print('send done') server.close()

#通过socket 实现简单的ssh#服务端

 #通过socket 实现简单的ssh#客户端

 #客户端

 import socket

 client = socket.socket()

 #client.connect(('192.168.16.200',9999))
client.connect(('localhost',9999)) while True:
cmd =input('>>>>:').strip()
if len(cmd) == 0:continue
client.send(cmd.encode('utf-8')) cmd_rer_size = client.recv(1024)#接收命令结果的长度(文件大小)
#cmd_res = client.recv(1024) print ('命令结果大小:',cmd_res._size) received_size = 0 received_data = b'' while received_size < int(cmd_res_size.decode()):
data = client.recv(1024)
received_size += len(data) #每次收到的有可能小于1024,所以必须用len判断
#print (data.decode())
#print (received_size)
received_data += data else:
print (' cmd res receive done...',received_size)
print (received_data.decode()) client.close()

#通过socket 实现简单的ssh#客户端

 '''

 #通过socket接收大数据2#服务端

 #通过socket 实现简单的ssh#服务端

 #服务端A
import time
import os
import socket server = socket.socket() server.bind(('0.0.0.0',9999))
#server.bind(('localhost',9999))
server.listen() while True:
conn,addr = server.accept()
print ('new conn:',addr)
while True:
print ('等待新指令')
data = conn.recv(1024)
if not data:
print ('客户端已经断开')
break print ('执行指令:',data)
cmd_res = os.popen(data.decode()).read()#接收字符串,执行结果也是字符串
print('before send',len(cmd_res))
if len(cmd_res) == 0 :
cmd_res = 'cmd has no output...' conn.send(str(len(cmd_res.encode())).encode('utf-8')) #先发文件大小给客户端
#time.sleep(0.5) #socket 粘包,解决方法不好 client_ack = conn.recv(1024) #等待客户端确认
print ('ack from client:',client_ack) conn.send(cmd_res.encode('utf-8'))
print('send done') server.close() '''
'''
import hashlib
m = hashlib.md5
m.update(b'test')
m.update(b'abc') ''' ''' #服务端B
import hashlib
import time
import os
import socket server = socket.socket() server.bind(('0.0.0.0',9999))
#server.bind(('localhost',9999))
server.listen() while True:
conn,addr = server.accept()
print ('new conn:',addr)
while True:
print ('等待新指令')
data = conn.recv(1024)
if not data:
print ('客户端已经断开')
break cmd,filename = data.decode().split()
print (filename) if os.path.isfile(filename):
f =open(filename,'rb')
m=hashlib.md5()
file_size =os.stat(filename).st_size
conn.send(str(file_size).encode())#文件大小
conn.recv(1024)#等待 ack
for line in f:
#m.update(line)
conn.send(line)
#print ('file md5',m.hexdigest())
f.close()
print('send done') server.close() ''' #服务端C
import hashlib
import time
import os
import socket server = socket.socket() server.bind(('0.0.0.0',9999))
#server.bind(('localhost',9999))
server.listen() while True:
conn,addr = server.accept()
print ('new conn:',addr)
while True:
print ('等待新指令')
data = conn.recv(1024)
if not data:
print ('客户端已经断开')
break cmd,filename = data.decode().split()
print (filename) if os.path.isfile(filename):
f =open(filename,'rb')
m=hashlib.md5()
file_size =os.stat(filename).st_size
conn.send(str(file_size).encode())#文件大小
conn.recv(1024)#等待 ack
for line in f:
m.update(line)
conn.send(line)
print ('file md5',m.hexdigest())
f.close()
conn.send(m.hexdigest().encode())#mp5 print('send done') server.close()

#通过socket接收大数据2#服务端

 '''
#通过socket接收大数据2#客户端 #通过socket 实现简单的ssh#客户端 #客户端A import socket client = socket.socket() #client.connect(('192.168.80.20',9999))
client.connect(('localhost',9999)) while True:
cmd =input('>>>>:').strip()
if len(cmd) == 0:continue
client.send(cmd.encode('utf-8')) cmd_rer_size = client.recv(1024)#接收命令结果的长度(文件大小)
#cmd_res = client.recv(1024) print ('命令结果大小:',cmd_res._size)
client.send('准备好接收了,loser可以发了'.encode('utf-8'))
received_size = 0 received_data = b'' while received_size < int(cmd_res_size.decode()):
data = client.recv(1024)
received_size += len(data) #每次收到的有可能小于1024,所以必须用len判断
#print (data.decode())
#print (received_size)
received_data += data else:
print (' cmd res receive done...',received_size)
print (received_data.decode()) client.close() ''' '''
#客户端B import socket client = socket.socket() #client.connect(('192.168.80.20',9999))
client.connect(('localhost',9999)) while True:
cmd =input('>>>>:').strip()
if len(cmd) == 0:continue
if cmd.startswith('get'):
client.send(cmd.encode())
server_response = client.recv(1024)
print ('servr response',server_response)
client.send(b'ready to recv file')
file_total_size = int (server_response.decode())
received_size = 0
filename = cmd.split()[1]
f =open (filename +'.new','wb')
while received_size < file_total_size:
data =client.recv(1024)
received_size += len(data)
f.write(data)
#print (file_total_size,received_size)
else:
print('file recv done',received_size,file_total_size)
f.close()
client.close() ''' #客户端C import socket
import hashlib
client = socket.socket() #client.connect(('192.168.80.20',9999))
client.connect(('localhost',9999)) while True:
cmd =input('>>>>:').strip()
if len(cmd) == 0:continue
if cmd.startswith('get'):
client.send(cmd.encode())
server_response = client.recv(1024)
print ('servr response',server_response)
client.send(b'ready to recv file')
file_total_size = int (server_response.decode())
received_size = 0
filename = cmd.split()[1]
f = open (filename +'.new','wb')
m = hashlib.md5() while received_size < file_total_size:
if file_total_size - received_size > 1024 :#要收不止一次
size =1024
else: #最后一次了,剩下多少收多少
size = file_total_size - received_size
print ('lastreceive:',size)
data =client.recv(size)
received_size += len(data)
m.update(data)
f.write(data)
#print (file_total_size,received_size)
else:
new_file_md5 = m.hexdigest()
print('file recv done',received_size,file_total_size)
f.close()
server_file_md5 = client.recv(1024)
print ('server file md5:',server_file_md5)
print ('clientr file md5:',new_file_md5) client.close()

#通过socket接收大数据2#客户端

 #socketserver基本使用#服务器端
'''
1 你必须创建一个请求处理类。并且这个类要继承BaseRequestHandler,
并且还要重写父亲类的handle() 2 你必须实例化TCPServer,并且传递server ip 和你上面创建的请求处理类
给这个TCPServer 3 调用 Server.handle_request()#只处理一个请求
Server.serve_forever()#处理多个请求,并且永远执行 4 关闭服务
''' #socketserver基本使用 import socketserver class MyTCPHandler(socketserver.BaseRequestHandler):
def handle(self):
while True:
try:
self.data =self.request.recv(1024).strip()
print ('{} wrote:'.format(self.client_address[0]))
print (self.data)
self.request.send(self.data.upper())
except ConnectionResetError as e:
print ('err,e')
break if __name__ == '__main__':
HOST,PORT = 'localhost',9999
server = socketserver.TCPServer((HOST,PORT),MyTCPHandler)
server.serve_forever()

#socketserver基本使用#服务器端

 #socketserver基本使用#客户端
'''
1 你必须创建一个请求处理类。并且这个类要继承BaseRequestHandler,
并且还要重写父亲类的handle() 2 你必须实例化TCPServer,并且传递server ip 和你上面创建的请求处理类
给这个TCPServer 3 调用 Server.handle_request()#只处理一个请求
Server.serve_forever()#处理多个请求,并且永远执行 4 关闭服务
''' #socketserver基本使用#客户端 import socket client = socket.socket()#声明socket类型,同时生成socket连接对象 client.connect(('localhost',9999)) while True:
msg =input('>>:').strip()
if len(msg) == 0:continue
client.send(msg.encode('utf-8'))
data = client.recv(10240)
print ('recv:',data.decode()) client.close()

#socketserver基本使用#客户端

 #socketserver 多线程(多并发)使用#服务端
'''
1 你必须创建一个请求处理类。并且这个类要继承BaseRequestHandler,
并且还要重写父亲类的handle() 2 你必须实例化TCPServer,并且传递server ip 和你上面创建的请求处理类
给这个TCPServer 3 调用 Server.handle_request()#只处理一个请求
Server.serve_forever()#处理多个请求,并且永远执行 4 关闭服务
'''
#普通socket地址重用
#server = socket.socket() #获得socket实例
#server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) #socketserver 地址重用
#self.allow_reuse_address import socketserver class MyTCPHandler(socketserver.BaseRequestHandler):
def handle(self):
while True:
try:
self.data =self.request.recv(1024).strip()
print ('{} wrote:'.format(self.client_address[0]))
print (self.data)
self.request.send(self.data.upper())
except ConnectionResetError as e:
print ('err,e')
break if __name__ == '__main__':
HOST,PORT = 'localhost',9999 server = socketserver.ThreadingTCPServer((HOST,PORT),MyTCPHandler)
server.serve_forever()

#socketserver 多线程(多并发)使用#服务端

 #socketserver 多进程使用#服务端 WIN不能使用
'''
1 你必须创建一个请求处理类。并且这个类要继承BaseRequestHandler,
并且还要重写父亲类的handle() 2 你必须实例化TCPServer,并且传递server ip 和你上面创建的请求处理类
给这个TCPServer 3 调用 Server.handle_request()#只处理一个请求
Server.serve_forever()#处理多个请求,并且永远执行 4 关闭服务
''' import socketserver class MyTCPHandler(socketserver.BaseRequestHandler):
def handle(self):
while True:
try:
self.data =self.request.recv(1024).strip()
print ('{} wrote:'.format(self.client_address[0]))
print (self.data)
self.request.send(self.data.upper())
except ConnectionResetError as e:
print ('err,e')
break if __name__ == '__main__':
HOST,PORT = 'localhost',9999
server = socketserver.ForkingTCPServer((HOST,PORT),MyTCPHandler)
server.serve_forever()

#socketserver 多进程使用#服务端 WIN不能使用

#socket #socketserver的更多相关文章

  1. socket - socketserver - start TCP server

    前面提到如何使用socket模块启动tcpserver: 创建socket:sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 绑定ip: ...

  2. python网络编程socket /socketserver

    提起网络编程,不同于web编程,它主要是C/S架构,也就是服务器.客户端结构的.对于初学者而言,最需要理解的不是网络的概念,而是python对于网络编程都提供了些什么模块和功能.不同于计算机发展的初级 ...

  3. python3之socket&socketserver网络编程

    1.套接字与套接模块 套接字是为特定网络协议(例如TCP/IP,ICMP/IP,UDP/IP等)套件对上的网络应用程序提供者提供当前可移植标准的对象.它们允许程序接受并进行连接,如发送和接受数据.为了 ...

  4. python Socket socketserver

    Socket 套接字 socket的 类型 实现socket对象时传入 到socket 类中 socket.AF_INET 服务器间的通讯 IPv4 socket.AF_INET6 IPv6 sock ...

  5. 进度条 --- socket ---socketserver

    TCP:可靠的面向连接的协议,传输效率低,全双工通信,流数据传输.运用:web浏览器,电子邮件,文件传输程序 UDP:不可靠的,无连接的服务,传输效率高,面向数据包的传输,只能发短消息.运用:dns ...

  6. socket&socketserver网络编程

    1.套接字与套接模块 套接字是为特定网络协议(例如TCP/IP,ICMP/IP,UDP/IP等)套件对上的网络应用程序提供者提供当前可移植标准的对象.它们允许程序接受并进行连接,如发送和接受数据.为了 ...

  7. Python学习之UDP版socket&SocketServer

    7.6 基于UDP的socket 无连接的,不必与对方建立连接,而是直接把数据发送给对方: 适用于一次传输销量数据结构,可靠性不高的应用环境,因为其传输速率快 # 服务端 import socket ...

  8. 小菜学习Winform(三)Socket点对点通信

    前言 Socket的英文原义是“孔”或“插座”,其实在网络编程中Socket就是这个意思,就像我们打电话,要首先知道对方的手机号一样,这个手机号就相当于一个Socket号.一个插座,在网络编程中就是i ...

  9. socketserver 分块记录

    网络编程 Socket(TCP,IP)套接字 服务端 运行起来, 客户端 客户端 客户端 客户端 服务端: import socket sk = socket.socket() #绑定端口号 sk.b ...

随机推荐

  1. iOS开发系列-NSOperation

    概述 NSOperation是基于GCD的封装更加面向对象,在使用上也是有任务跟队列的概念,分别对应两个类NSOperation .NSOperationQueue NSOperation和NSOpe ...

  2. 2019-10-4-C#-极限压缩-dotnet-core-控制台发布文件

    title author date CreateTime categories C# 极限压缩 dotnet core 控制台发布文件 lindexi 2019-10-04 14:59:36 +080 ...

  3. php非法输入数据类型

    1.空白输入 2.超长输入(如大于256个字符) 3.特殊字符(如·!@#¥%……&*()—=|.:‘:<>;'"<>?.,) 4.控制字符(如\r\n等) ...

  4. c# 中反射里的invoke方法的参数

    一个最简单的C#反射实例,首先编写类库如下: namespace ReflectionTest { public class WriteTest { //带参数的公共方法 public void Wr ...

  5. vue初学之node.js安装、cnpm安装、vue初体验

    1. 如果本机没有安装node运行环境,请下载node 安装包进行安装.地址:https://nodejs.org/en/ 2.装完,使用cmd命令行输入:node -v回车 如果输出版本号则成功. ...

  6. Ubuntu 快速安装配置Odoo 12

    Odoo 12预计将于今年10月正式发布,这是一次大版本更新,带来了一些不错的新特性,如 文件管理系统(DMS) 用户表单中新增字段(Internal user, Portal, Public) HR ...

  7. zabbix被监控端代理设置

    zabbix被监控端代理设置 安装zabbix-agent客户端 rpm -ivh https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-re ...

  8. Java中的String真的无法修改吗

    Java中String一旦赋值将无法修改,每次对String值的修改都是返回新的String. 如何在不创建新的String对象的情况下,对String的值进行修改呢? String类中的包含一个字段 ...

  9. Windows安全证书生成方法(开发者证书)

    首先,查看本机安装的证书可在“运行”中输入:certmgr.msc 一.win8.8.1.win10系统,使用管理员powershell创建证书: (1)利用如下命令来创建证书并获取到其指纹 New- ...

  10. dp练习集

    动态规划(DP) // 以下题目来自牛客网 删括号 f[i][j][k] 表示序列s的前i个匹配序列t的前j个,序列s删除部分左括号与右括号数量差为k的情况是否可行 答案为 f[sl][tl][0] ...