1

1.1 server:

#!/use/local/env python
# -*- coding:utf-8 -*- import socket ip_port = ('127.0.0.1', 9999)
#ip_port = ('0.0.0.0', 9999) #所有IP
sk = socket.socket()
sk.bind(ip_port)
sk.listen(5) while True:
print('server wainting ...')
conn, add = sk.accept() client_data = conn.recv(1024)
print(str(client_data, encoding='utf-8'))
conn.sendall(bytes('不要回答,不要回答,不要回答', encoding='utf-8'))
# conn.sendall(bytes('不要回答,不要回答,不要回答', 'utf-8'))
# conn.sendall(bytes('不要回答,不要回答,不要回答', 'utf8')) conn.close() 1.2 client:
#!/use/local/env python
# -*- coding:utf-8 -*- import socket ip_port = ('127.0.0.1', 9999)
sk = socket.socket()
sk.connect(ip_port) sk.sendall(bytes('请求占领地球,请求占领地球,请求占领地球', encoding='utf-8'))
server_reply = sk.recv(1024)
print(str(server_reply, encoding='utf-8'))
sk.close() 2
2.1 server:
#!/use/local/env python
# -*- coding:utf-8 -*- import socket ip_port = ('127.0.0.1', 9999)
#ip_port = ('0.0.0.0', 9999) #所有IP
sk = socket.socket()
sk.bind(ip_port)
sk.listen(5) while True:
print('server wainting ...')
conn, add = sk.accept() client_data = conn.recv(1024) #字符数
print(str(client_data, encoding='utf-8'))
conn.sendall(bytes('不要回答,不要回答,不要回答', encoding='utf-8'))
# conn.sendall(bytes('不要回答,不要回答,不要回答', 'utf-8'))
# conn.sendall(bytes('不要回答,不要回答,不要回答', 'utf8')) while True:
try:
client_data2 = conn.recv(1024)
except Exception:
break
conn.send(client_data2) conn.close() 2.2 client:
#!/use/local/env python
# -*- coding:utf-8 -*- import socket ip_port = ('127.0.0.1', 9999)
sk = socket.socket()
sk.connect(ip_port) sk.sendall(bytes('请求占领地球,请求占领地球,请求占领地球', encoding='utf-8'))
server_reply = sk.recv(1024)
print(str(server_reply, encoding='utf-8'))
while True:
user_input = input(">>").strip()
sk.sendall(bytes(user_input, encoding='utf-8'))
server_reply2 = sk.recv(1024)
print(str(server_reply2, encoding='utf-8')) sk.close() 3 ssh_socket
3.1 server
#!/usr/local/env python
# -*- coding:utf-8 -*- import socket, subprocess num = 100 sk = socket.socket()
ip_port = ('0.0.0.0', 9999)
sk.bind(ip_port)
sk.listen(5) count = 0
while True:
count += 1
print("server is waiting [%s]..." %count)
conn, add = sk.accept()
#client_data = conn.recv(1024)
#print(str(client_data, encoding='utf-8'))
#conn.sendall(bytes('不要回答{3}', encoding='utf-8')) while True:
client_data = conn.recv(num)
if not client_data:
print('recv is empty')
break
cmd_str = str(client_data, encoding='utf-8')
cmd_call = subprocess.Popen(cmd_str, shell=True, stdout=subprocess.PIPE)
cmd_res = cmd_call.stdout.read()
if len(cmd_res) == 0:
#if not cmd_res:
cmd_res = b"has no output!\n"
conn.send(cmd_res)
conn.close()
3.2 client
#!/usr/local/env python
# -*- encoding:utf-8 -*- import socket num = 100
sk = socket.socket()
ip_port = ('10.100.11.211', 9999)
sk.connect(ip_port) while True:
user_input = input('cmd>').strip()
if len(user_input) == 0:
continue
elif user_input == 'q':
break
sk.sendall(bytes(user_input, encoding='utf-8')) server_data = sk.recv(num)
print(str(server_data, encoding='utf-8'), end='')
while not (len(server_data) < num):
server_data = sk.recv(num)
print(str(server_data, encoding='utf-8'), end='')
sk.close() 4 ssh传大数据
4.1 server
#!/usr/local/env python
# -*- coding:utf-8 -*- import socket, subprocess num = 500 sk = socket.socket()
ip_port = ('0.0.0.0', 9999)
sk.bind(ip_port)
sk.listen(5) count = 0
while True:
count += 1
print("server is waiting [%s]..." %count)
conn, add = sk.accept()
#client_data = conn.recv(1024)
#print(str(client_data, encoding='utf-8'))
#conn.sendall(bytes('不要回答{3}', encoding='utf-8')) while True:
client_data = conn.recv(num)
if not client_data:
print('recv is empty')
break
cmd_str = str(client_data, encoding='utf-8')
cmd_call = subprocess.Popen(cmd_str, shell=True, stdout=subprocess.PIPE)
cmd_res = cmd_call.stdout.read()
if len(cmd_res) == 0:
#if not cmd_res:
cmd_res = b"has no output!\n"
CMD_RES_SIZE_MSG = bytes('SEND_DATA_SIZE:%s' %(len(cmd_res)), encoding='utf-8') conn.send(CMD_RES_SIZE_MSG)
conn.recv(50)
conn.send(cmd_res)
conn.close()
4.2 client
#!/usr/local/env python
# -*- encoding:utf-8 -*- import socket num = 500
sk = socket.socket()
ip_port = ('10.100.11.211', 9999)
sk.connect(ip_port) while True:
user_input = input('cmd>').strip()
if len(user_input) == 0:
continue
elif user_input == 'q':
break
sk.sendall(bytes(user_input, encoding='utf-8')) CMD_SIZE_MSG = sk.recv(50)
CMD_SIZE_MSG = str(CMD_SIZE_MSG, encoding='utf-8')
#CMD_RES_SIZE_MSG = 'SEND_DATA_SIZE:%s' %(len(cmd_res))
CDM_SIZE_GET = CMD_SIZE_MSG.split(':')
CMD_SIZE = 0
if CDM_SIZE_GET[0] == 'SEND_DATA_SIZE':
CMD_SIZE = int(CDM_SIZE_GET[1])
CMD_ACK = b'ready'
sk.send(CMD_ACK) recv_size = 0
while recv_size < CMD_SIZE:
server_data = sk.recv(num)
recv_size += len(server_data)
print(str(server_data, encoding='utf-8'), end='') #print(str(server_data, encoding='utf-8'), end='')
#while not (len(server_data) < num):
# server_data = sk.recv(num)
# print(str(server_data, encoding='utf-8'), end='')
sk.close()

socket模块的更多相关文章

  1. socket编程--socket模块介绍

    socket也称作'套接字,用于描述IP地址和端口,是一个通信的终点. socket起源于Unix,而Unix/Linux基本哲学之一就是"一切皆文件",对于文件用[打开][读写] ...

  2. Python中的socket 模块

    Python 提供了两个基本的 socket 模块.第一个是 Socket,它提供了标准的 BSD Sockets API.第二个是 SocketServer, 它提供了服务器中心类,可以简化网络服务 ...

  3. Python网络编程(2)——socket模块(2)

    目录: 1. 异常 2. 地址族 3. 套接字类型 4. 模块方法 5. Socket对象与实例方法 socket模块提供了Python中的低层网络连接接口,用于操作套接字操作. 异常 socket模 ...

  4. 第五十五节,IO多路复用select模块加socket模块,伪多线并发

    IO多路复用select模块加socket模块,伪多线并发,并不是真正的多线程并发,实际通过循环等待还是一个一个处理的 IO多路复用,lo就是文件或数据的输入输出,IO多路复用就是可以多用户操作 IO ...

  5. 第五十三节,socket模块介绍,socket单线程通讯

    socket单线程通讯,只能单线程通讯,不能并发 socket是基于(TCP.UDP.IP)的通讯.也叫做套接字 通讯过程由服务端的socket处理信息发送,由客户端的socket处理信息接收. so ...

  6. 老李分享:使用 Python 的 Socket 模块开发 UDP 扫描工具

    老李分享:使用 Python 的 Socket 模块开发 UDP 扫描工具 poptest是业内唯一的测试开发工程师培训机构,测试开发工程师主要是为测试服务开发测试工具,在工作中要求你做网络级别的安全 ...

  7. python实战第一天-socket模块练习

    操作系统 Ubuntu 15.10 IDE & editor JetBrains PyCharm 5.0.2 ipython3 Python版本 python-3.4.3 导入socket模块 ...

  8. python学习记录-socket模块

    主要使用的模块是socket模块,在这个模块中可以找到socket()函数,该函数用于创建套接字对象.套接字也有自己的方法集,这些方法可以实现基于套接字的网络通信. 1.socket类型 构造函数: ...

  9. 网络协议,socket模块

    """网络通讯要素:1.物理介质2.通讯协议 osi五层模型 应用层 传输层 网络层 数据链路层 物理层 物理层能传输010101二进制单纯的二进制是没有意义的,必须得知 ...

  10. python之socket模块详解--小白博客

    主要是创建一个服务端,在创建服务端的时候,主要步骤如下:创建socket对象socket——>绑定IP地址和端口bind——>监听listen——>得到请求accept——>接 ...

随机推荐

  1. 防止忘记初始化NSMutableArray的方法

    在写项目的过程中,经常会遇到一些郁闷的事,往一个可变数组中添加一个模型数据时,经常会发现程序运行很正常,可是可变数组中就是没有任何数据,久病成医,我发现自己总是放一个错,就是NSMutableArra ...

  2. JS 代理模式

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. hdu3911 线段树 区间合并

    //Accepted 3911 750MS 9872K //线段树 区间合并 #include <cstdio> #include <cstring> #include < ...

  4. Android Studio开发环境变量配置

    1,Android Studio官网可以下载 可以选择下载带有SDK版本 2,如果没有配置SDK,AVD虚拟机是没法使用的,真机调试也用不了. 有时会提醒adb is not connected. 和 ...

  5. 虚拟机安装Linux系统图文教程

    虚拟机安装Linux系统图文教程 | 浏览:523 | 更新:2014-09-16 15:31 1 2 3 4 5 6 7 分步阅读 Linux系统的安装 工具/原料 VMware 9.0 虚拟机 L ...

  6. Java Abstract Class

    在Baths-stomp里面的每个Fluent Interface Interactor Impl,都继承了MarketDataAccessor,which is an abstract class. ...

  7. java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState解决?

    做项目到最后整合的时候测试的时候发现  切换tab更换fragment的时候抛出了这个异常,根据异常信息Can not perform this action after onSaveInstance ...

  8. iOS应用中通过设置VOIP模式实现休眠状态下socket的长连接

    如果你的应用程序需要在设备休眠的时候还能够收到服务器端发送的消息,那我们就可以借助VOIP的模式来实现这一需求.但是如果的应用程序并不是正真的VOIP应用,那当你把你的应用提交到AppStore的时候 ...

  9. Juniper SRX防火墙-NAT学习笔记!

    Junos NAT第一部分:SRX NAT介绍第二部分:Source NAT:Interface NAT第三部分:Source NAT:Address Pools第四部分:Destination NA ...

  10. Java 集合深入理解(9):Queue 队列

    点击查看 Java 集合框架深入理解 系列, - ( ゜- ゜)つロ 乾杯~ 今天心情不太好,来学一下 List 吧! 什么是队列 队列是数据结构中比较重要的一种类型,它支持 FIFO,尾部添加.头部 ...