当前位置: 首页 > article >正文

Python实战:5分钟用OpenSSL自签名证书保护你的C/S应用(附完整代码)

Python实战5分钟用OpenSSL自签名证书保护你的C/S应用附完整代码在开发客户端/服务器C/S应用时数据传输安全往往是最容易被忽视的环节。许多开发者习惯在测试环境中使用明文通信等到上线前才匆忙添加加密功能——这种先开发后安全的做法往往会导致各种兼容性问题。本文将带你用Python和OpenSSL在5分钟内为现有C/S应用添加SSL/TLS加密层让你的测试环境也能享受生产级的安全保障。1. 为什么需要自签名证书想象一下这样的场景你的C/S应用正在传输用户凭证或敏感业务数据而某个中间人通过简单的网络嗅探就获取了所有信息。自签名证书虽然不能像CA签发的证书那样获得浏览器信任但在开发和测试阶段它能提供与正规证书完全相同的加密强度。自签名证书的三大核心优势即时可用无需等待CA审核一键生成零成本省去购买商业证书的开销完全控制自定义有效期、加密算法等参数注意自签名证书仅推荐用于开发和测试环境生产环境应使用受信任CA签发的证书2. OpenSSL快速入门生成证书的三种姿势2.1 基础单行命令openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -days 365 -nodes这条命令会生成4096位的RSA私钥key.pem有效期1年的自签名证书cert.pem免密码保护-nodes参数2.2 带Subject信息的专业版本openssl req -x509 -newkey rsa:4096 \ -subj /CCN/STBeijing/LHaidian/OYourCompany/CNlocalhost \ -keyout server.key -out server.crt -days 3650 -nodes参数说明/C国家代码CN表示中国/ST省份/CN常用名必须与访问域名一致2.3 分步生成适合进阶需求# 生成私钥 openssl genrsa -out private.key 2048 # 创建证书签名请求(CSR) openssl req -new -key private.key -out request.csr # 自签名生成证书 openssl x509 -req -in request.csr -signkey private.key -out certificate.crt -days 3653. Python SSL模块深度整合3.1 服务端改造实战原始socket服务端import socket server socket.socket() server.bind((0.0.0.0, 8443)) server.listen(5)安全升级版import socket import ssl context ssl.SSLContext(ssl.PROTOCOL_TLS_SERVER) context.load_cert_chain(server.crt, server.key) server socket.socket() server.bind((0.0.0.0, 8443)) server.listen(5) secure_server context.wrap_socket(server, server_sideTrue)关键参数解析ssl.PROTOCOL_TLS_SERVER自动选择双方支持的最高TLS版本server_sideTrue明确指定这是服务端socket3.2 客户端安全连接基础连接方式import socket import ssl context ssl.create_default_context() context.check_hostname False # 禁用主机名验证仅测试用 context.verify_mode ssl.CERT_NONE # 不验证证书 client socket.socket() secure_client context.wrap_socket(client) secure_client.connect((localhost, 8443))生产级安全配置验证证书context ssl.create_default_context(cafileserver.crt) context.verify_mode ssl.CERT_REQUIRED4. 常见问题排雷指南4.1 证书验证失败错误现象ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED]解决方案# 客户端代码中添加 context.load_verify_locations(server.crt)4.2 协议版本不匹配错误现象ssl.SSLError: [SSL: WRONG_VERSION_NUMBER]修复方案# 服务端明确指定协议版本 context ssl.SSLContext(ssl.PROTOCOL_TLSv1_2)4.3 性能优化参数context.options | ssl.OP_NO_COMPRESSION # 禁用压缩防止CRIME攻击 context.set_ciphers(ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384)5. 完整示例加密聊天应用服务端代码import socket import ssl context ssl.SSLContext(ssl.PROTOCOL_TLS_SERVER) context.load_cert_chain(server.crt, server.key) responses { hello: Hi there!, time: Current time is ..., bye: Goodbye! } with socket.socket() as sock: sock.bind((0.0.0.0, 8443)) sock.listen() with context.wrap_socket(sock, server_sideTrue) as secure_sock: while True: conn, addr secure_sock.accept() with conn: data conn.recv(1024).decode() response responses.get(data.lower(), Unknown command) conn.send(response.encode())客户端代码import socket import ssl context ssl.create_default_context(cafileserver.crt) with socket.socket() as sock: with context.wrap_socket(sock, server_hostnamelocalhost) as secure_sock: secure_sock.connect((localhost, 8443)) while True: cmd input( ) secure_sock.send(cmd.encode()) print(secure_sock.recv(1024).decode())性能测试数据1000次请求对比加密方式平均延迟吞吐量明文TCP1.2ms8500/sTLS 1.33.8ms3200/sTLS 1.24.5ms2800/s实际项目中如果只是保护内网通信使用TLS 1.3带来的性能损失完全可以接受。我在某金融测试项目中采用这种方案后不仅满足了安全审计要求还因为标准化配置减少了30%的部署问题。

相关文章:

Python实战:5分钟用OpenSSL自签名证书保护你的C/S应用(附完整代码)

Python实战:5分钟用OpenSSL自签名证书保护你的C/S应用(附完整代码) 在开发客户端/服务器(C/S)应用时,数据传输安全往往是最容易被忽视的环节。许多开发者习惯在测试环境中使用明文通信,等到上线…...

Java charAt 方法与字符编码变换实践

本文深入探讨了Java方法decrString,该方法利用charAt获取字符串字符,并根据字符索引的奇偶加减ASCII值,以实现简单的字符编码转换。本文详细分析了该方法的实现原理和字符算术的特点,并通过具体的例子显示了其转换效果&#xff0c…...

如何为Java初学者配置最简洁的开发环境

对于Java初学者来说,配置开发环境不需要复杂的工具堆叠。重点是快速启动,减少干扰,专注于语法和编程思维的学习。最简单的环境只有三个部分:简化JDK、轻量级编辑器,基本命令行操作。 选择适合初学者的JDK版本和发行版…...

保姆级教程:用ROS Noetic在Ubuntu 20.04上配置RealSense D455与机械臂手眼标定(附常见错误排查)

ROS Noetic环境下RealSense D455与机械臂手眼标定实战指南 环境准备与基础配置 在Ubuntu 20.04系统中配置ROS Noetic与RealSense D455相机的开发环境是构建eye-in-hand视觉系统的第一步。与常见的D435系列不同,D455作为升级型号,在深度精度和IMU性能上都…...

Java中如何使用Scanner读取输入数据

位于Java的Scanner类是Java中读取用户输入的常用工具.util包中。创建Scanner实例,并将其传输到System。.in,nextint()可以使用、nextDouble()等方法读取基本数据类型;读取空格字符串需要nextline(),但要注意nextline()后需要调用n…...

Spring新手必看:IOC容器中Bean的5个关键操作(含containsBean使用场景)

Spring新手必看:IOC容器中Bean的5个关键操作(含containsBean使用场景) Spring框架作为Java生态中最受欢迎的轻量级容器,其核心机制IOC(控制反转)彻底改变了我们管理对象依赖的方式。对于刚接触Spring的开发…...

黑盒 vs 白盒测试:5个真实项目案例教你如何选择测试方法

黑盒与白盒测试实战指南:5个行业案例解析方法论选择 在软件质量保障领域,测试方法的选择往往决定着缺陷检测效率和项目交付质量。当金融系统的转账功能出现逻辑错误时,当电商促销活动页面突然崩溃时,背后往往存在着测试策略的失误…...

从零到一:手把手教你用Android Studio离线打包UniApp安卓应用

1. 环境准备:搭建离线打包的基础设施 第一次接触UniApp离线打包时,最让人头疼的就是环境配置。记得我刚开始尝试时,光是安装Android Studio就反复折腾了三遍。这里我会把踩过的坑都帮你避开,让你一次性搞定所有依赖。 首先需要准备…...

好用还专业!10个降AIGC软件全学科适配测评,帮你高效降AI率

在学术写作日益依赖AI工具的今天,论文的AIGC率问题逐渐成为学生和研究者关注的焦点。如何在保持原文语义通顺的前提下有效降低AI痕迹,成为了论文修改过程中不可忽视的一环。AI降重工具的出现,正是为了解决这一难题。它们通过智能算法识别并优…...

实测才敢推!全领域适配降重神器 —— 千笔·专业降AIGC智能体

在AI技术快速发展的今天,越来越多的学生和研究人员开始依赖AI工具辅助论文写作,提升效率与质量。然而,随之而来的AI生成内容痕迹过重、查重率偏高问题也日益凸显。面对知网、维普、万方等平台对AI内容的严格检测,以及Turnitin对AI…...

降重压力小了!全领域适配的降AIGC神器 —— 千笔

在AI技术迅猛发展的今天,越来越多的学生和研究人员开始依赖AI工具进行论文写作,以提高效率和质量。然而,随着学术审核标准的不断提升,AI生成内容的痕迹越来越容易被检测出来,导致论文出现“AI率超标”问题,…...

Outlookmail Plus

链接:https://pan.quark.cn/s/0d68dd538fae用于统一管理 Outlook / IMAP 邮箱账号、读取邮件、提取验证码,并支持邮箱池调度的 Web 项目(or 注册机...

KRed播放器

链接:https://pan.quark.cn/s/1b70ab9353cf软件功能:音视频播放器支持平台:#Windows软件简介:一款免费的音视频播放器,兼容MP4、MKV、AVI、MOV等主流视频格式,以及MP3、FLAC、APE、AAC等无损音频&#xff0…...

Midscene:浏览器自动化的革新者与效率引擎

Midscene:浏览器自动化的革新者与效率引擎 【免费下载链接】midscene Let AI be your browser operator. 项目地址: https://gitcode.com/GitHub_Trending/mid/midscene 你是否曾因重复的网页操作而感到厌倦?当面对需要定期执行的浏览器任务时&am…...

不用UI组件也能搞定!纯CSS实现文字省略号+悬浮显示完整内容(附代码)

纯CSS实现文字截断与悬浮提示:轻量级前端开发实战 在快节奏的前端开发中,我们常常需要在有限空间内展示大段文本。传统解决方案往往依赖UI组件库的Tooltip或Popover功能,但这会引入额外的依赖和性能开销。本文将深入探讨如何仅用CSS和原生HTM…...

壁纸下载网站

链接:https://pan.quark.cn/s/e6f051577797收录有游戏、电影、汽车、自然风光、动漫、抽象艺术等多种类型的壁纸,提供多种分辨率如1080P、2K、4K甚至8K,并且所有壁纸都可以免费下载。...

“基于matlab字符匹配的车牌识别系统”(含GUI界面与详细代码,可做学习参考及包含视频教程

基于matlab字符匹配的车牌识别系统 【车牌识别】基于计算机视觉,数字图像处理,模板匹配算法(含GUI界面) 系统内数据库丰富,车牌识别速度快,并包含识别率检测功能,目前识别率可达到73% 代码系统完…...

网络安全加固:AI头像生成器API防护策略

网络安全加固:AI头像生成器API防护策略 1. 引言:AI头像生成器的安全挑战 最近AI头像生成器真是火得不行,各种应用都在集成这个功能。用户上传一张照片,几秒钟就能生成各种风格的专业头像,从卡通动漫到写实风格&#…...

保姆级避坑指南:一次通过OceanBase OBCA线上考试的10个关键细节(含设备/网络/监考)

保姆级避坑指南:一次通过OceanBase OBCA线上考试的10个关键细节(含设备/网络/监考) 1. 设备准备:别让硬件问题毁掉你的考试 参加OBCA线上考试,设备是第一个需要严格把关的环节。很多考生因为忽略了一些看似简单的细节…...

开发者必备:OpenClaw+Qwen3-32B实现日志分析与错误排查

开发者必备:OpenClawQwen3-32B实现日志分析与错误排查 1. 为什么需要自动化日志分析 作为一个长期与日志打交道的开发者,我经历过太多深夜排查问题的痛苦时刻。某次线上事故中,我花了整整三个小时人工筛选2GB的Nginx日志,最终发…...

Vitis 2023.2实战:从XSA到Linux应用程序的完整开发流程(附常见错误排查)

Vitis 2023.2实战:从XSA到Linux应用程序的完整开发流程(附常见错误排查) 在嵌入式系统开发领域,Xilinx的Vitis工具链为FPGA开发者提供了从硬件设计到软件开发的完整解决方案。本文将深入探讨如何利用Vitis 2023.2版本,…...

Claude Code 分布式并行开发最佳实践:1中枢+10Worker跨多Git仓库全流程落地

Claude Code 分布式并行开发最佳实践:1中枢+10Worker跨多Git仓库全流程落地 在多仓库、微服务、全栈开发的场景下,开发者常面临「多任务并行开发冲突、跨仓库依赖难协调、分支污染风险高、AI编码效率低」等核心痛点。本文基于 Claude Code 原生能力 + Git Worktree 隔离机制…...

《ShardingSphere解读》13 路由引擎:如何理解分片路由核心类 ShardingRouter 的运作机制?

前面我们对 ShardingSphere 中的 SQL 解析引擎做了介绍,我们明白 SQL 解析的作用就是根据输入的 SQL 语句生成一个 SQLStatement 对象。 从今天开始,我们将进入 ShardingSphere 的路由(Routing)引擎部分的源码解析。从流程上讲&am…...

Z-Image-GGUF部署教程:SSH端口转发+本地浏览器访问远程服务器完整流程

Z-Image-GGUF部署教程:SSH端口转发本地浏览器访问远程服务器完整流程 📝 最后更新:2026年2月26日 🎨 基于阿里通义实验室 Z-Image 模型 🔧 GGUF 量化版本,低显存友好 1. 快速开始:30秒上手文生图…...

vs code , 配置 claude code 插件, 默认选项 : --dangerously-skip-permission

文章目录 一、核心配置步骤(含风险提醒) 方式1:通过VS Code图形界面配置(新手友好) 方式2:直接编辑settings.json(精准配置) 验证配置是否生效 二、关键注意事项 总结 一、核心配置步骤(含风险提醒) 首先需要明确:--dangerously-skip-permission 是 Claude Code 插…...

DVWA 靶场实战:从零到一的 Web 安全攻防演练

1. DVWA靶场入门:Web安全攻防演练环境搭建 第一次接触DVWA时,我花了两小时才把环境跑起来。这个用PHP/MySQL编写的漏洞演练平台,简直是安全初学者的宝藏。下面分享我的踩坑经验,帮你10分钟搞定环境搭建。 核心组件准备&#xff1a…...

网络工程师实战:用iperf3做企业级网络质量检测(TCP/UDP全参数解析)

网络工程师实战:用iperf3做企业级网络质量检测(TCP/UDP全参数解析) 当企业网络出现视频会议卡顿、文件传输缓慢或云服务延迟时,传统的ping和traceroute往往只能给出"网络有问题"的模糊结论。作为网络工程师,…...

百川2-13B-4bits镜像免配置价值:省去Linux系统级CUDA驱动校验、Python虚拟环境创建等前置步骤

百川2-13B-4bits镜像免配置价值:省去Linux系统级CUDA驱动校验、Python虚拟环境创建等前置步骤 1. 引言:当大模型部署不再“劝退” 如果你曾经尝试在本地部署一个百亿参数级别的大语言模型,大概率会经历这样的“劝退”流程: 检查…...

算法对决:排序遍历 vs 分治法——谁才是众数查找的性能王者?

算法对决:排序遍历 vs 分治法——谁才是众数查找的性能王者? 在数据处理领域,众数查找是一个经典问题。面对百万级甚至更大规模的数据集时,算法选择直接影响系统性能。本文将深入剖析两种主流方法——排序遍历法和分治法&#xff…...

保姆级教程:使用SuperMap iClient for OpenLayers加载超图服务的完整流程(含坐标系转换技巧)

SuperMap iClient与OpenLayers融合开发实战:从坐标系原理到地图服务加载 当你第一次尝试将SuperMap的地图服务集成到OpenLayers项目中时,可能会被各种专业术语和坐标系问题搞得晕头转向。作为GIS开发领域的黄金组合,SuperMap iClient for Ope…...