网络编程socketserver
一、网络编程回顾
tcp是流式传输,字节流,数据与数据之间没有边界
优点:不限定长度,可靠传输
缺点:慢,和一端的通信连接conn会一直占用通信资源
udp协议式面向数据包的传输
优点:快,由于不需要建立连接,哪一端发送消息都能收到
缺点:不能传输过长的数据,不可靠
黏包现象:
由于tcp协议流式传输的特点,产生了数据连续发送的黏包现象
在一个链接建立起来的连接上传输的多余数据是没有边界的
数据的发送和接收实际上不是执行send/recv的时候就立即被发送或者接收,而是经过操作系统内核。
NAGLE算法能够将发送间隔时间很近的短数据合成一个包发送到接收端
拆包机制:当要发送的数据超过网络上能传输的最大长度,就会被tcp协议强制拆包
解决黏包问题(连续两次send):
如果是短数据,告诉接收端的边界即可
如果是长数据,不仅告诉接收端的边界,还需保证接收端完整地接收
二、其他方法及参数
客户端套接字函数
s.connect() 主动初始化TCP服务器连接
s.connect_ex() connect()函数的扩展版本,出错时返回出错码,而不是抛出异常
公共用途的套接字函数
s.recv() 接收TCP数据
s.send() 发送TCP数据,会自动拆分发送
s.sendall() 发送TCP数据
s.recvfrom() 接收UDP数据
s.sendto() 发送UDP数据
s.getpeername() 连接到当前套接字的远端的地址
s.getsockname() 当前套接字的地址
s.getsockopt() 返回指定套接字的参数
s.setsockopt() 设置指定套接字的参数
s.close() 关闭套接字
面向锁的套接字方法
s.setblocking() 设置套接字的阻塞与非阻塞模式
s.settimeout() 设置阻塞套接字操作的超时时间
s.gettimeout() 得到阻塞套接字操作的超时时间
面向文件的套接字的函数
s.fileno() 套接字的文件描述符
s.makefile() 创建一个与该套接字相关的文件
其他参数:
socket.socket(family=AF_INET,type=SOCK_STREAM,proto=0,fileno=None)
type = SOCK_STREAM (默认TCP协议)
family = AF_INET (默认网络通信)
AF_INET6 (基于ipv6)
AF_UNIX (基于本地通过文件通信)
fileno = None 指定了fileno,其他参数都无效,基于文件操作
三、验证客户端连接的合法性 —— 增强连接的安全性
实现原理:server端生成一个随机的字符串,发送到client端,通过处理随机字符串获得一个结果,接收到client端处理的结果,对比成功继续通信,否则就关闭连接
# server端
import socket
import hmac
import os sk = socket.socket()
sk.bind(('127.0.0.1',8899))
sk.listen()
#
conn,addr = sk.accept()
code = os.urandom(32) # 生成32位bytes类型的随机字节码
conn.send(code) # 给接收端发送验证码
key = b'abc' # 定义bytes类型的盐
ret = hmac.new(key,code) # 通过加密算法将随机字节码转为密文,接收的参数都是bytes类型
result = ret.digest() # 通过digest获取结果 client_digest = conn.recv(1024) # 获得client端加密后的结果
if result == client_digest: # 对比结果是否一致
print('合法的连接')
conn.send('开始对话'.encode('utf-8'))
else:
print('不合法的连接')
conn.close()
# client客户端
import socket
import hmac sk = socket.socket()
sk.connect_ex(('127.0.0.1',8899))
code = sk.recv(32)
key = b'abc'
ret = hmac.new(key,code)
sk.send(ret.digest()) print(str(sk.recv(1024),'utf-8'))
四、socketserver模块
socket是socketserver的底层模块,socketserver在socket的基础上做了进一步的封装
基于tcp协议的server不需要导入socket,直接导入socketserver即可
socketserver必须使用面向对象编程
# server端
import socketserver
class Myserver(socketserver.BaseRequestHandler):
def handle(self):
conn = self.request
conn.send(b'hello')
print(str(conn.recv(1024),'utf-8')) socketserver.TCPServer.allow_reuse_address = True # # 设置allow_reuse_address允许服务器重用地址
server = socketserver.ThreadingTCPServer(('127.0.0.1',9000),Myserver) # 创建一个server的服务
server.serve_forever() # 让server永远运行下去,除非强制停止程序
# client端
import socket
sk = socket.socket() sk.connect_ex(('127.0.0.1',9000))
print(str(sk.recv(1024),'utf-8'))
sk.send('goodbye'.encode('utf-8'))
sk.close()
网络编程socketserver的更多相关文章
- Socket网络编程-SocketServer
Socket网络编程-SocketServer 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.SocketServer概述 socket编程过于底层,编程虽然有套路,但是想要写 ...
- python网络编程——SocketServer/Twisted/paramiko模块
在之前博客C/S架构的网络编程中,IO多路复用是将多个IO操作复用到1个服务端进程中进行处理,即无论有多少个客户端进行连接请求,服务端始终只有1个进程对客户端进行响应,这样的好处是节省了系统开销(se ...
- 网络编程-socketserver
网络编程使用socketserver,通常包括以下几步:一.定义类,并继承socketserver.BaseRequestHandler 二.重写handle方法 三.实例化TCPServer,并传递 ...
- python网络编程socketserver模块(实现TCP客户端/服务器)
摘录python核心编程 socketserver(python3.x版本重新命名)是标准库中的网络编程的高级模块.通过将创建网络客户端和服务器所必须的代码封装起来,简化了模板,为你提供了各种各样的类 ...
- 38 - 网络编程-socketserver
目录 1 socket编程弊端 2 SocketServer模块 2.1 服务器类 2.2 Mixin类 2.3 RequestHandlerClass是啥 2.4 编程接口 3 实现EchoServ ...
- python基础(15)-socket网络编程&socketserver
socket 参数及方法说明 初始化参数 sk = socket.socket(参数1,参数2,参数3) 参数1:地址簇 socket.AF_INET IPv4(默认) socket.AF_INET6 ...
- 【python】网络编程-SocketServer 实现客户端与服务器间非阻塞通信
利用SocketServer模块来实现网络客户端与服务器并发连接非阻塞通信.首先,先了解下SocketServer模块中可供使用的类:BaseServer:包含服务器的核心功能与混合(mix-in)类 ...
- python网络编程-socketserver
一:socketserver简化了网络服务器的编写. 它有4个类:TCPServer,UDPServer,UnixStreamServer,UnixDatagramServer. 这4个类是同步进行处 ...
- python网络编程--socketserver 和 ftp功能简单说明
1. socketserver 我们之前写的tcp协议的socket是不是一次只能和一个客户端通信,如果用socketserver可以实现和多个客户端通信.它是在socket的基础上进行了一层封装,也 ...
随机推荐
- doris: shell invoke .sql script for doris and passing values for parameters in sql script.
1. background in most cases, we want to execute sql script in doris routinely. using azkaban, to l ...
- LeetCode_217. Contains Duplicate
217. Contains Duplicate Easy Given an array of integers, find if the array contains any duplicates. ...
- MySQL普通索引性能试验
首先使用如下node.js脚本创建两张表,并为这两张表各自生成10000条数据: var fs = require('fs'); var nameS = "赵钱孙李周吴郑王冯陈褚卫蒋沈韩杨朱 ...
- 常见浏览器CSS hack方法总结
ie6和ie7 #tip {*background:black; /*IE7 背景变黑色*/_background:orange; /*IE6 背景变橘色*/} IE8和IE9 :root .test ...
- iOS底层框架浅析
1.简介 IOS是由苹果公司为iPhone.iPod touch和iPad等设备开发的操作系统. 2.知识点 iPhone OS(现在叫iOS)是iPhone, iPod touch 和 iPad 设 ...
- Python文件的读取写入操作
一.打开文件.关闭文件操作 想要读取文件或是写入文件,第一步便是打开文件,最后一步便是关闭文件.这里介绍两种打开(关闭)文件的方式: 1.open()方法 f=open(file_name[,acce ...
- gitstats 统计gitlab仓库中的代码
使用Git版本库,有一些可视化的工具,如gitk,giggle等,来查看项目的开发历史.但对于大型的项目,这些简单的可视化工具远远不足以了解项目完整的开发历史,一些定量的统计数据(如每日提交量,行数等 ...
- CentOS 7 搭建 GitLab
概述 GitLab 是我在日常工作中使用的代码仓库管理系统,它带有非常友好的 Web 界面,并且功能丰富.下面将介绍我在 CentOS 7 上搭建 GitLab 的步骤,以及遇到的一些问题. 关于不同 ...
- 微信小程序中的事件绑定
前言: 微信小程序中的事件绑定和Vue中的事件绑定其实有很多的相似之处,所以如果有过Vue相关的经验,学起来的话还是比较容易的. js代码: // 页面级的js文件必须调用Page函数来注册页面, / ...
- 使用java类加载器,报异常java.nio.file.InvalidPathException
String path = Label.class.getClassLoader().getResource("").getPath(); /F:/idea-Java/ImageD ...