Python网络通信
day26
网络通信
参考:
http://www.cnblogs.com/yuanchenqi/articles/5692716.html

男生是client端,字条是socket(sk),通过sk通信。
socket属于客户端。应用程序两端通过“套接字”向网络发出请求或者应答网络请求。可以把socket理解为通信的把手(hand)。
确定对端IP地址→ 确定应用程序端口 → 确定通讯协议

server下的方法
bind()
listen()
accept()
recv()
send()#传送内容必须为bytes类型
sendall()
close()
client下的方法
connect()
recv()
send()
aendall()
close()
client发送,serve接收

serve.py
import socket
sk = socket.socket()#创建socket
print(sk)
address = ('127.0.0.1', 8000)#本机地址
sk.bind(address)#为socket绑定IP和端口号
sk.listen(3)#限制排队的个数
print('waiting......')
conn, addr = sk.accept()#conn为客户端socket对象
#
# inp = input('>>>')
# conn.send(bytes(inp, 'utf8'))
data = conn.recv(1024)#为什么用conn,而不用sk
print(str(data, 'utf8'))
# conn.close()#关具体对象
# sk.close()#全关
client.py
import socket sk = socket.socket() print(sk)
address = ('127.0.0.1', 8000) sk.connect(address) #data = sk.recv(1024)#收到的为bytes类型
data = sk.send(bytes('hah', 'utf8')) #print(str(data, 'utf8'))
运行serve.py
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>
waiting......
waiting,accept()阻塞。
运行client.py
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>
Process finished with exit code 0
serve收到数据“hah”
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>
waiting......
hah
Process finished with exit code 0
client接收,serve发送
serve.py
import socket
sk = socket.socket()#创建socket
print(sk)
address = ('127.0.0.1', 8000)#本机地址
sk.bind(address)#为socket绑定IP和端口号
sk.listen(3)#限制排队的个数
print('waiting......')
conn, addr = sk.accept()#conn为客户端socket对象
inp = input('>>>')
conn.send(bytes(inp, 'utf8'))
# data = conn.recv(1024)#为什么用conn,而不用sk
# print(str(data, 'utf8'))
# conn.close()#关具体对象
# sk.close()#全关
client.py
import socket sk = socket.socket() print(sk)
address = ('127.0.0.1', 8000) sk.connect(address) data = sk.recv(1024)#收到的为bytes类型
#data = sk.send(bytes('hah', 'utf8')) print(str(data, 'utf8'))
运行serve.py
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>
waiting......
运行client.py
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>
在serve命令行输入hello
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>
waiting......
>>>hello
Process finished with exit code 0
client命令行收到数据。
<socket.socket fd=3, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('0.0.0.0', 0)>
hello
Process finished with exit code 0
不间断聊天
client.py
import socket sk = socket.socket() print(sk)
address = ('127.0.0.1', 8000)
sk.connect(address) while True:
inp = input('>>>')
if inp == 'exit':
break
sk.send(bytes(inp, 'utf8')) data = sk.recv(1024)
print(str(data, 'utf8')) sk.close()
#print(sk)
serve.py
import socket
sk = socket.socket()#创建socket
print(sk)
address = ('127.0.0.1', 8000)#本机地址
sk.bind(address)#为socket绑定IP和端口号
sk.listen(3)#限制排队的个数
print('waiting......')
#conn, addr = sk.accept()#conn为客户端socket对象
while True:
conn, addr = sk.accept()
print(addr) #client打开则接收
while True:
#收
try:
data = conn.recv(1024)#为什么用conn,而不用sk,client关闭时报错误
except Exception:
break #client端停止,他也停止
print('.......',str(data, 'utf8'))
if not data:break
#发
inp = input('>>>')
conn.send(bytes(inp, 'utf8'))
sk.close()#全关
不间断聊天,其中client若关闭,新开一个client,serve端还能继续服务。
粘包现象(远程执行命令)
cmd_client.py
import socket sk = socket.socket() print(sk)
address = ('127.0.0.1', 8001)
sk.connect(address) while True:
inp = input('>>>')
if inp == 'exit':
break
sk.send(bytes(inp, 'utf8'))
result_len = int(str(sk.recv(1024), 'utf8')) sk.sendall(bytes('ok', 'utf8'))#收到长度信息后,告诉server data = bytes()#初始化
while len(data) != result_len: #等于原文件大小,说明接收完
recv = sk.recv(1024)
data += recv print(str(data, 'utf8')) sk.close()
#print(sk)
cmd_server.py
import socket
import subprocess
sk = socket.socket()#创建socket print(sk) address = ('127.0.0.1', 8001)#本机地址
sk.bind(address)#为socket绑定IP和端口号 sk.listen(3)#限制排队的个数
print('waiting......')
#conn, addr = sk.accept()#conn为客户端socket对象 while True:
conn, addr = sk.accept()
print(addr) #client打开则接收
while True:
#收
try:
data = conn.recv(1024)#为什么用conn,而不用sk,client关闭时报错误
except Exception:
break #client端停止,他也停止
print('.......',str(data, 'utf8')) if not data:break
obj = subprocess.Popen(str(data, 'utf8'), shell = True, stdout = subprocess.PIPE)
cmd_result = obj.stdout.read()#以上执行结果
#print(cmd_result)
result_len = bytes(str(len(cmd_result)), 'utf8') conn.sendall(result_len)#发
#先向client发送数据,client若收到则向server发送OK,Server再发送处理结果
#若连续发送,两个发送内容(长度,处理结果)可能会合并。
re = conn.recv(1024)#防止粘包
if str(re, 'utf8') != 'ok':
break
#发
conn.sendall(cmd_result) # conn.sendall(result_len) # 这种方式会发生粘包现象,长度和内容合在一起了
# conn.sendall(cmd_result)
sk.close()#全关
先执行server.py,再执行client.py,在client中输入命令(dir,pwd,ifconfig等)
Python网络通信的更多相关文章
- Python网络通信 (一)
ISO(国际标准化组织)--->网络体系结构标准 OSI模型 OSI 七层模型 应用层 :提供用户服务,具体内容由特定程序规定 表示层 :提供数据的压缩解压和加密等 会话层 :建立程序级的连接, ...
- FastNet C++/Python 网络通信库之 协议
协议可以使用的基础数据类型: UInt8,UInt16,UInt32,UInt64Int8,Int16,Int32,Int64Float,Double,Bool,String [T] 数组,T代表元 ...
- Python—网络通信编程之tcp非阻塞通信(socketserver)
服务端代码 import socketserver # 定义一个类 class MyServer(socketserver.BaseRequestHandler): # 如果handle方法出现报错, ...
- Python—网络通信编程之udp通信编程
服务端代码 import socket # 1.创建实例,即数据报套接字 server = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 2.绑 ...
- Python—网络通信编程之tcp通信编程
服务端代码 import socket # 1.创建流式套接字实例 # server = socket.socket() server = socket.socket(socket.AF_INET, ...
- python中Socket的使用
说明 前一段时间学习python网络编程,完成简单的通过python实现网络通信的功能.现在,将python中Socket 通信的基本实现过程做一个记录备份. Socket通信 python 中的so ...
- twisted是python实现的基于事件驱动的异步网络通信构架。
网:https://twistedmatrix.com/trac/ http://www.cnblogs.com/wy-wangyan/p/5252271.html What is Twisted? ...
- 百万年薪python之路 -- 网络通信原理
1. C/S B/S架构 C: Client 客户端 B: Browse 浏览器 S: Server 服务端 C/S架构: 基于客户端与服务端之间的通信 eg: QQ,微信,LOL,DNF等需要安装A ...
- python中的网络通信,socket、select、selectors、socketserver
楔子 网络通信用于获取一个算法在本地运行所需的数据,还可以共享信息实现分布式处理,另外可以用来管理云服务. python的标准库提供了一些模块来创建网络服务以及访问现有服务ipaddress模块提供了 ...
随机推荐
- loadrunner--TPS和平均事务响应时间
TPS就是每秒事务数,但是事务是基于虚拟用户数的,假如1个虚拟用户在1秒内完成1笔事务,那么TPS明显就是1:如果 某笔业务响应时间是1ms,那么1个用户在1秒内能完成1000笔事务,TPS就是100 ...
- 多线程的使用:只能用cmd来玩不能用idle
from multiprocessing import Process import os def pro_do(name, func): print () if __name__ == " ...
- Docker 技巧:删除 Docker 容器和镜像
默认安装完 docker 后,每次执行 docker 都需要运行 sudo 命令,非常浪费时间影响效率.如果不跟 sudo,直接执行 docker images 命令会有如下问题: Get http: ...
- [VC++入门]指针一
俗话说没有搞清楚指针就没有学会C/C++,所以指针是一个相当重要的东东,相当年在用 C#调用C++写的动态链接库时,以为C++中的指针就是C#中的引用类型(ref),但是看了一下却不是这样.指针当然和 ...
- 优秀前端工程师必备: 非常常用的checkbox的骚操作---全选和单选demo
提要: 前端开发的时候, 经常会遇到表格勾选, 单个勾选判断是否全选的事情.趁着有时间, 总结一下以备不时之需! 就像下面这个栗子: 1 源代码: h5 // 全选框 <input type=& ...
- nexus 参考文档
参考文档: http://books.sonatype.com/nexus-book/reference/index.html E:\e\nexus\nexus-2.12.0-01\conf\nexu ...
- 批量远程执行shell命令工具
使用示例(使用了默认用户root,和默认端口号22): ./mooon_ssh --h=192.168.4.1,192.168.4.2 -P=password -c='cat /etc/hosts' ...
- ubuntu16.4中开启vncserver进行远程桌面
使用x11vnc作为vncserver端 1 安装x11vnc $ sudo apt-get update $ sudo apt-get install x11vnc 2 生成密码 $ x11vnc ...
- onclick传参
var tema="<a title='打开' href='javascript:;' onclick='showKnowledgeMap(1,\" "+kl_na ...
- MFC-CWinApp
概览 CWinApp为应用程序类, CWinApp由 CWinThread 派生而来 ,后者表示可能具有一个或多个线程的应用程序的主执行线程,基于框架生成的应用程序必须有且仅有一个从 CWinApp ...