0

0

Python 如何安全地处理用户输入?

冷漠man

冷漠man

发布时间:2026-01-19 12:32:02

|

486人浏览过

|

来源于php中文网

原创

Python安全处理用户输入的核心是不信任外部数据,须验证类型范围、转义上下文、隔离环境:用正则校验格式,参数化防SQL注入,html.escape防XSS,pathlib防路径遍历,pydantic做模型校验,框架启用CSRF/XSS防护,限制请求大小与资源访问。

python 如何安全地处理用户输入?

Python 安全处理用户输入的核心是:不信任任何外部数据,始终做验证、转义和上下文隔离。

对输入内容做类型和范围校验

用户输入可能是字符串、数字、布尔值等,但实际传入的往往都是字符串。直接用 int(input())json.loads() 解析可能引发异常或逻辑漏洞。

  • str.strip() 去除首尾空格,避免隐藏字符干扰
  • 对数字类输入,先用 str.isdigit() 或正则判断格式,再转类型;或用 try/except 捕获转换异常
  • 邮箱、手机号、日期等,用预编译的正则表达式匹配合法格式(如 r'^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$'
  • 限制长度(如用户名 ≤20 字符)、禁止特殊字符(如 SQL 关键字、路径分隔符 /..

在不同上下文中做针对性转义

同一段输入,在 HTML 渲染、SQL 查询、系统命令、JSON 输出等场景下,风险点和防护方式完全不同。

  • 输出到 HTML 页面时,用 html.escape() 转义 >& 等字符,防止 XSS
  • 拼接 SQL 语句时,绝不用字符串格式化(f"SELECT * FROM users WHERE name = '{name}'"),改用参数化查询(cursor.execute("SELECT * FROM users WHERE name = %s", (name,))
  • 调用系统命令前,优先用 Python 原生模块(如 os.listdir() 替代 os.system(f"ls {path}"));必须调用时,用 subprocess.run([...], shell=False) 并传入列表参数
  • 生成 JSON 时,用 json.dumps() 自动处理引号和编码,不要手动拼接

使用成熟库替代手写解析逻辑

很多常见输入格式已有经过安全审计的解析器,比自己写正则或切片更可靠。

顶级域名交易系统
顶级域名交易系统

1.后台管理登陆直接在网站地址后输入后台路径,默认为 /admin,进入后台管理登陆页面,输入管理员用户名和密码,默认为 中文 admin ,登陆后台。2.后台管理a.注销管理登陆 (离开后台管理时,请点击这里正常退出,确保系统安全)b.查看使用帮助 (如果你在使用系统时,有不清楚的,可以到这里来查看)c.管理员管理 (这里可以添加,修改,删除系统管理员,暂不支持,分权限管理操作)d.分类管理 (

下载

立即学习Python免费学习笔记(深入)”;

  • URL 处理用 urllib.parse(如 urlparse()quote()),避免自己拆解 scheme/host/path
  • 文件路径用 pathlib.Pathos.path.normpath() + os.path.abspath() 校验是否在允许目录内,防止路径遍历(../../etc/passwd
  • 配置或表单数据用 pydantic 定义模型,自动完成类型转换、默认值填充、字段校验(如 @validator('age') def age_must_be_positive(cls, v): ...
  • Web 框架中启用内置防护:Flask 开启 WTF_CSRF_ENABLED,Django 默认开启 XSS 转义和 CSRF 中间件

设置输入边界与运行环境隔离

即使代码逻辑正确,失控的输入仍可能耗尽资源或突破沙箱。

  • 限制请求体大小(如 Flask 的 MAX_CONTENT_LENGTH = 16 * 1024 * 1024
  • 对上传文件检查 content_type 和后缀名,重命名文件名(如用 UUID),保存到独立目录,禁止执行权限
  • 敏感操作(如删除、转账)要求二次确认或短期 Token 验证,不单靠前端传来的参数
  • 在容器或虚拟环境中运行服务,限制 CPU、内存、网络和文件系统访问范围

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

760

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

639

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

762

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

619

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1285

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

3

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 4.7万人学习

Django 教程
Django 教程

共28课时 | 3.2万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号