python socketserver模块开启ssl双向认证

server端代码如下

复制代码
import socketserver
import ssl

# 需要校验客户端
ssl_context = ssl.create_default_context(ssl.Purpose.CLIENT_AUTH)
# 发给客户端
ssl_context.load_cert_chain(certfile="./server.crt", keyfile="./server.key")
# 信任库
ssl_context.load_verify_locations(./ca.crt")
ssl_context.verify_mode=ssl.CERT_REQUIRED
# 检查主机名是否与提供的证书中的主机名匹配
ssl_context.check_hostname=False



class MyHandler(socketserver.BaseRequestHandler):
    def handle(self):
        # 接收客户端的数据
        data = self.request.recv(1024).strip()
        print(f'Received from client: {data.decode()}')
        # 发送响应给客户端
        response = b'Hello, Client!'
        self.request.sendall(response)


if __name__ == '__main__':
    server = socketserver.TCPServer(('0.0.0.0', 1234), MyHandler)
    server.socket = ssl_context.wrap_socket(server.socket, server_side=True)
    server.serve_forever()

client端代码如下

复制代码
import socket
import ssl

# 定义服务器的地址和端口
server_address = ('localhost', 1234)
ssl_context = ssl.SSLContext(ssl.PROTOCOL_TLS)
ssl_context.check_hostname = False
# 加载证书链,用于发给对端,相当于keystore
ssl_context.load_cert_chain(certfile="./server.crt", keyfile="./server.key")
ssl_context.verify_mode=ssl.CERT_REQUIRED
# trustStore
ssl_context.load_verify_locations(cafile="D:\code\Quantity\ca.crt")
# 创建一个TCP套接字
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
csocket = ssl_context.wrap_socket(client_socket, server_side=False)
try:
    # 连接到服务器
    csocket.connect(server_address)

    # 发送数据给服务器
    data = b'Hello, Server!'
    csocket.sendall(data)

    # 接收服务器的响应数据
    response = csocket.recv(1024)
    print('Received from server:', response.decode())
finally:
    # 关闭客户端套接字
    csocket.close()

双向认证证书生成:https://blog.csdn.net/u014644574/article/details/126190061

相关推荐
喵手5 分钟前
Python爬虫实战:电商问答语料构建完整实战 - 从爬取到检索语料的工程化实现(附CSV导出 + SQLite持久化存储)!
爬虫·python·sqlite·爬虫实战·零基础python爬虫教学·电商问答语料构建·爬取到检索语料
REDcker17 分钟前
Media Source Extensions (MSE) 详解
前端·网络·chrome·浏览器·web·js
天荒地老笑话么36 分钟前
Bridged 下“能上网但内网不可达”:路由/防火墙排查
网络·网络安全
APIshop39 分钟前
淘宝商品评论接口实战解析:从抓包到数据抓取全链路技术指南
java·python
~央千澈~41 分钟前
抖音弹幕游戏开发之第14集:添加更多整蛊效果·优雅草云桧·卓伊凡
开发语言·python·游戏
开开心心_Every1 小时前
局域网大文件传输,设密码双向共享易用工具
运维·服务器·网络·游戏·pdf·电脑·excel
天荒地老笑话么1 小时前
Bridged 下 IP 冲突:冲突识别与修复
网络·网络协议·tcp/ip
袁袁袁袁满2 小时前
Linux网络连接之ss命令详细使用指南(从入门到运维实战)
linux·运维·服务器·网络·ssh·网络连接·ss命令
Ronin3052 小时前
信道管理模块
网络·rabbitmq·网络通信
航哥的女人2 小时前
基于TCP的socket编程
网络·网络协议·tcp/ip