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模块提供了 ...
随机推荐
- zabbix分布式系统监视
http://blog.chinaunix.net/uid-25266990-id-3380929.html
- 5 个关键点!优化你的 UI 原型设计
当你和你的团队着手开始一个产品开发的时候,最开始的一步一般是绘制线框图,这是大部分产品项目的第一步,它不复杂但是却对整个产品的完成形态和质量有着至关重要的作用. 很多刚开始工作设计师或者产品经理都会提 ...
- 简明PR教程
注意:本文供培训使用且仅为第一版 作者也不打算继续更新 本篇文章最早是在为内部培训时所编写的文章 有些疏漏且没有进行校正等工作 我尽力用最简单通俗的语言给大家介绍PR的使用方法 简明PR教程 1.编辑 ...
- Windows10(uwp)开发中的侧滑
还是在持续的开发一款Windows10的应用中,除了上篇博客讲讲我在Windows10(uwp)开发中遇到的一些坑,其实还有很多不完善的地方,比如(UIElement.Foreground).(Gra ...
- MySQL的left on 【zt】
MySQL的left on [zt] (2008-11-03 17:27:30) 转载▼ 标签: it 分类: 学习笔记 MySQL多表连接查询Left Join,Right Join php开源嘛 ...
- 2018.09.26 bzoj4326: NOIP2015 运输计划(二分+树上差分)
传送门 简单树上操作. 先转边权为点权. 显然所有的询问操作对应的路径会有一些交点,那么我们可以直接二分答案,对于所有大于二分值的询问用树上差分维护,最后dfs一遍每个点被覆盖了几次,当前情况合法当且 ...
- 2018.08.06 bzoj1500: [NOI2005]维修数列(非旋treap)
传送门 平衡树好题. 我仍然是用的fhqtreap,感觉速度还行. 维护也比线段树splay什么的写起来简单. %%%非旋treap大法好. 代码: #include<bits/stdc++.h ...
- HDU 2546 饭卡 (01背包问题)
题意:中文的吧,飘过~ 析:学过DP的都应该感觉到是动态规划吧,就是一个01背包问题,不同的是,这个题又加入一些新的条件,就是不满5元不能消费,过了5元即使超了也行(这个学校真不错,都可以预支),最后 ...
- HDU 2393 Higher Math (判断直角三角形)
题意:给定三个边,判断是不是直角三角形. 析:水题,勾股定理... 代码如下: #include <iostream> #include <cstdio> #include & ...
- Android在layout xml中使用include[转]
在Android的layout样式定义中,可以使用xml文件方便的实现,有时候为了模块的复用,使用include标签可以达到此目的.例如: <include layout="@layo ...