Python:简易的 TCP + SSL 服务端与客户端示例

下面是一个完整的 TCP + SSL 服务端与客户端示例,适用于 Python 3,使用 socket 模块和 ssl 模块,常用于实现安全通信。

一、生成 SSL 证书和私钥

打开命令行(终端),输入以下命令生成自签名证书(有效期 365 天)。

cs 复制代码
openssl req -new -x509 -days 365 -nodes -out server.crt -keyout server.key

按照提示填写(可以直接回车),将生成两个文件:

server.crt:服务器端证书

server.key:服务器私钥

这两个文件需与服务端脚本放在同一目录下。

提示:

要在系统中事先安装 OpenSSL。

Windows 用户可通过 Git Bash 或安装 OpenSSL for Windows。

https://slproweb.com/products/Win32OpenSSL.html

二、TCP + SSL 服务端(server_tcp_ssl.py)

python 复制代码
import socketimport ssl
HOST = '127.0.0.1'PORT = 8888
# 创建 TCP socketserver_sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)server_sock.bind((HOST, PORT))server_sock.listen(1)print("等待客户端连接...")
# 加载证书和密钥context = ssl.SSLContext(ssl.PROTOCOL_TLS_SERVER)context.load_cert_chain(certfile='server.crt', keyfile='server.key')
# 包装 socketwith context.wrap_socket(server_sock, server_side=True) as ssock:    conn, addr = ssock.accept()    print("客户端已连接:", addr)
    try:        while True:            data = conn.recv(1024)            if not data:                break            print("收到消息:", data.decode('utf-8'))            reply = input("回复客户端:")            conn.sendall(reply.encode('utf-8'))    except Exception as e:        print("通信异常:", e)    finally:        conn.close()

三、TCP + SSL 客户端(client_tcp_ssl.py)

python 复制代码
import socketimport ssl
HOST = '127.0.0.1'PORT = 8888
context = ssl.create_default_context()context.check_hostname = Falsecontext.verify_mode = ssl.CERT_NONE  # 忽略证书验证(测试用)
try:    with socket.create_connection((HOST, PORT)) as sock:        with context.wrap_socket(sock, server_hostname=HOST) as ssock:            print("已连接服务器,可发送消息(输入 q 退出)")
            while True:                msg = input("你说:")                if msg.lower() == 'q':                    break                ssock.sendall(msg.encode('utf-8'))                reply = ssock.recv(1024).decode('utf-8')                print("服务器回应:", reply)
except Exception as e:    print("连接异常:", e)

◆ ◆

使用说明

1、先运行服务端,建议在命令行中运行。

nginx 复制代码
python server_tcp_ssl.py

确保服务端所在端口未被防火墙拦截。

2、再运行客户端(client_tcp_ssl.py)。可在 Python 编辑器中运行。

如遇 UnicodeDecodeError,请确认服务端与客户端使用统一编码(UTF-8)。

3、客户端或服务端输入文字后回车,对方会回应。

4、在客户端输入 q 键即可退出。

"点赞有美意,赞赏是鼓励"

相关推荐
fouryears_234172 小时前
Flutter InheritedWidget 详解:从生命周期到数据流动的完整解析
开发语言·flutter·客户端·dart
我好喜欢你~3 小时前
C#---StopWatch类
开发语言·c#
lifallen4 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研4 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi5 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
mit6.8245 小时前
[1Prompt1Story] 滑动窗口机制 | 图像生成管线 | VAE变分自编码器 | UNet去噪神经网络
人工智能·python
没有bug.的程序员5 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
玩转以太网5 小时前
基于W55MH32Q-EVB 实现 HTTP 服务器配置 OLED 滚动显示信息
服务器·网络协议·http
甄超锋5 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
cui__OaO6 小时前
Linux软件编程--线程
linux·开发语言·线程·互斥锁·死锁·信号量·嵌入式学习