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网络通信的更多相关文章

  1. Python网络通信 (一)

    ISO(国际标准化组织)--->网络体系结构标准 OSI模型 OSI 七层模型 应用层 :提供用户服务,具体内容由特定程序规定 表示层 :提供数据的压缩解压和加密等 会话层 :建立程序级的连接, ...

  2. FastNet C++/Python 网络通信库之 协议

    协议可以使用的基础数据类型: UInt8,UInt16,UInt32,UInt64Int8,Int16,Int32,Int64Float,Double,Bool,String [T]  数组,T代表元 ...

  3. Python—网络通信编程之tcp非阻塞通信(socketserver)

    服务端代码 import socketserver # 定义一个类 class MyServer(socketserver.BaseRequestHandler): # 如果handle方法出现报错, ...

  4. Python—网络通信编程之udp通信编程

    服务端代码 import socket # 1.创建实例,即数据报套接字 server = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 2.绑 ...

  5. Python—网络通信编程之tcp通信编程

    服务端代码 import socket # 1.创建流式套接字实例 # server = socket.socket() server = socket.socket(socket.AF_INET, ...

  6. python中Socket的使用

    说明 前一段时间学习python网络编程,完成简单的通过python实现网络通信的功能.现在,将python中Socket 通信的基本实现过程做一个记录备份. Socket通信 python 中的so ...

  7. twisted是python实现的基于事件驱动的异步网络通信构架。

    网:https://twistedmatrix.com/trac/ http://www.cnblogs.com/wy-wangyan/p/5252271.html What is Twisted? ...

  8. 百万年薪python之路 -- 网络通信原理

    1. C/S B/S架构 C: Client 客户端 B: Browse 浏览器 S: Server 服务端 C/S架构: 基于客户端与服务端之间的通信 eg: QQ,微信,LOL,DNF等需要安装A ...

  9. python中的网络通信,socket、select、selectors、socketserver

    楔子 网络通信用于获取一个算法在本地运行所需的数据,还可以共享信息实现分布式处理,另外可以用来管理云服务. python的标准库提供了一些模块来创建网络服务以及访问现有服务ipaddress模块提供了 ...

随机推荐

  1. loadrunner--TPS和平均事务响应时间

    TPS就是每秒事务数,但是事务是基于虚拟用户数的,假如1个虚拟用户在1秒内完成1笔事务,那么TPS明显就是1:如果 某笔业务响应时间是1ms,那么1个用户在1秒内能完成1000笔事务,TPS就是100 ...

  2. 多线程的使用:只能用cmd来玩不能用idle

    from multiprocessing import Process import os def pro_do(name, func): print () if __name__ == " ...

  3. Docker 技巧:删除 Docker 容器和镜像

    默认安装完 docker 后,每次执行 docker 都需要运行 sudo 命令,非常浪费时间影响效率.如果不跟 sudo,直接执行 docker images 命令会有如下问题: Get http: ...

  4. [VC++入门]指针一

    俗话说没有搞清楚指针就没有学会C/C++,所以指针是一个相当重要的东东,相当年在用 C#调用C++写的动态链接库时,以为C++中的指针就是C#中的引用类型(ref),但是看了一下却不是这样.指针当然和 ...

  5. 优秀前端工程师必备: 非常常用的checkbox的骚操作---全选和单选demo

    提要: 前端开发的时候, 经常会遇到表格勾选, 单个勾选判断是否全选的事情.趁着有时间, 总结一下以备不时之需! 就像下面这个栗子: 1 源代码: h5 // 全选框 <input type=& ...

  6. nexus 参考文档

    参考文档: http://books.sonatype.com/nexus-book/reference/index.html E:\e\nexus\nexus-2.12.0-01\conf\nexu ...

  7. 批量远程执行shell命令工具

    使用示例(使用了默认用户root,和默认端口号22): ./mooon_ssh --h=192.168.4.1,192.168.4.2 -P=password -c='cat /etc/hosts' ...

  8. ubuntu16.4中开启vncserver进行远程桌面

    使用x11vnc作为vncserver端 1 安装x11vnc $ sudo apt-get update $ sudo apt-get install x11vnc 2 生成密码 $ x11vnc ...

  9. onclick传参

    var tema="<a title='打开' href='javascript:;' onclick='showKnowledgeMap(1,\" "+kl_na ...

  10. MFC-CWinApp

    概览 CWinApp为应用程序类, CWinApp由 CWinThread 派生而来 ,后者表示可能具有一个或多个线程的应用程序的主执行线程,基于框架生成的应用程序必须有且仅有一个从 CWinApp ...