0

0

Python 自动化运维的安全边界

舞夢輝影

舞夢輝影

发布时间:2026-02-17 14:58:03

|

299人浏览过

|

来源于php中文网

原创

执行shell命令须防注入:优先用subprocess.run(["cmd", arg], shell=false);若需shell=true,必须shlex.quote()包裹变量;读写文件前校验路径与权限;调用第三方库需关闭危险默认;日志需字段级脱敏。

python 自动化运维的安全边界

执行 shell 命令时别直接拼接用户输入

subprocess.run()os.system() 调外部命令,只要参数里混了未经处理的用户输入(比如从 API、文件、日志里读的字符串),就等于给攻击者开了个 shell 注入后门。

常见错误现象:subprocess.run("ls " + user_path, shell=True) —— 用户传 "/tmp; rm -rf /" 就真删了。

  • 永远优先用 shell=False(默认值),把命令和参数拆成列表:subprocess.run(["ls", user_path])
  • 如果非得用 shell=True(比如要管道、通配符),必须先用 shlex.quote() 包裹每个变量:subprocess.run(f"ls {shlex.quote(user_path)}", shell=True)
  • 注意:shlex.quote() 只防注入,不解决路径越界问题;后续还得校验 user_path 是否在允许目录内

读写敏感文件前先做权限与路径双重校验

自动化脚本常要读 /etc/passwd、写 /var/log/myapp/,但 Python 的 open() 不管你有没有权限,也不拦着你写到 /root/.ssh/authorized_keys

使用场景:批量修改配置、轮转日志、同步密钥文件。

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

互连在线双语商务版
互连在线双语商务版

全自动化、全智能的在线方式管理、维护、更新的网站管理系统主要功能如下:一、系统管理:管理员管理,可以新增管理员及修改管理员密码;数据库备份,为保证您的数据安全本系统采用了数据库备份功能;上传文件管理,管理你增加产品时上传的图片及其他文件。二、企业信息:可设置修改企业的各类信息及介绍。 三、产品管理:产品类别新增修改管理,产品添加修改以及产品的审核。四、订单管理:查看订单的详细信息及订单处理。 五、

下载
  • os.path.realpath() 解析绝对路径,再检查是否落在白名单根目录下:if not real_path.startswith("/etc/"): → 拒绝
  • os.stat() 查目标文件权限位,确认不是 world-writable(stat.S_IWOTH)或属主不是 root 但你要改它
  • 写文件时优先用 tempfile.NamedTemporaryFile(delete=False) 写临时文件,再 os.replace() 原子替换,避免写一半崩溃留下脏数据

调用第三方库前看清它默认开没开危险开关

很多运维常用库(比如 paramikoansible-corerequests)为方便,默认行为其实有安全妥协。

典型例子:paramiko.SSHClient() 默认跳过主机密钥验证,requests.get(url, verify=False) 关闭 TLS 证书校验。

  • paramiko 必须显式调用 load_system_host_keys()set_missing_host_key_policy(),别留空
  • requests 禁用 verify=False,生产环境用 verify="/path/to/ca-bundle.crt"
  • ansible playbook 中避免裸写 become: yes,要配合 become_userbecome_method 明确限定提权范围

日志和异常信息别把凭证/路径/命令原样打出来

调试时习惯性 logger.error(f"Failed to run {cmd} with {env}") ,结果日志里全是数据库密码、API token、完整命令行——这些全进了 ELK 或 Sentry。

性能影响不大,但一旦日志被误导出或权限配置松动,就是泄露源头。

  • 对日志内容做字段级脱敏:匹配 r"(password|token|key|secret)[^=]*=[^&\s]+" 并替换成 "***"
  • 异常堆栈里可能带敏感路径,用 traceback.format_exc() 后手动过滤再记录
  • 开发期可用 logging.basicConfig(level=logging.DEBUG),上线前务必关掉 DEBUG,至少设为 WARNING

真正难的不是加几行校验,而是每次 touch 到系统边界(exec、open、net、log)时,都得下意识问一句:这个变量谁给的?它能被谁控制?我有没有假设它“可信”?

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

815

2023.08.22

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.25

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6396

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

835

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1084

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

1599

2024.03.01

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

553

2023.08.03

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

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

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