你不得不知道的10个最危险的Python函数
off999 2025-06-10 00:33 64 浏览 0 评论
在Python中,某些函数如果使用不当,可能导致 安全漏洞、数据损坏、系统崩溃 甚至 远程代码执行(RCE)。以下是 10个最危险的Python函数,开发者必须谨慎使用:
1.eval()与exec()
危险等级: (最高)
风险: 任意代码执行
user_input = "os.system('rm -rf /')" # 恶意输入
eval(user_input) # 直接删除系统文件!安全替代方案:
# 使用字典或JSON解析可控数据
import ast
safe_data = ast.literal_eval('{"key": "value"}') # 仅解析基本数据结构2.pickle反序列化
危险等级:
风险: 反序列化恶意对象导致RCE
import pickle
malicious_data = b"\x80\x04\x95...\x94." # 构造的恶意pickle数据
pickle.loads(malicious_data) # 触发任意代码执行安全替代方案:
import json
safe_data = json.loads('{"key": "value"}') # 仅处理JSON数据
3.os.system()/subprocess.run(shell=True)
危险等级:
风险: 命令注入
filename = input("文件名: ") # 用户输入: 'test.txt; rm -rf /'
os.system(f"cat {filename}") # 执行了删除命令!安全替代方案:
import subprocess
subprocess.run(["cat", filename], shell=False) # 参数列表形式4.marshal模块
危险等级:
风险: 与pickle类似,但设计用于Python字节码,更危险
import marshal
malicious_code = compile("os.system('rm -rf /')", "<string>", "exec")
marshal.dumps(malicious_code) # 可被反序列化执行永远不要反序列化不可信的marshal数据!
5.yaml.load()
危险等级:
风险: YAML反序列化漏洞(PyYAML)
import yaml
malicious_yaml = "!!python/object/apply:os.system ['rm -rf /']"
yaml.load(malicious_yaml) # 执行系统命令安全替代方案:
yaml.safe_load("{key: value}") # 仅解析简单数据结构
6.tempfile.mktemp()
危险等级:
风险: 竞争条件漏洞(TOCTOU)
import tempfile
temp_path = tempfile.mktemp() # 不安全:文件名可能被劫持
with open(temp_path, 'w') as f: # 攻击者可在此间隙创建同名文件
f.write("data")安全替代方案:
with tempfile.NamedTemporaryFile(delete=True) as f: # 自动处理文件句柄
f.write(b"data")7.shutil.rmtree()
危险等级:
风险: 误删关键目录
安全实践:
import send2trash # 第三方库
send2trash.send2trash("/home/user/data") # 先放回收站8.glob模块(路径遍历)
危险等级:
风险: 路径注入
import glob
user_input = "../../*" # 恶意输入
files = glob.glob(f"/data/{user_input}") # 访问上级目录安全防护:
import os
user_input = os.path.basename(input()) # 过滤路径
files = glob.glob(f"/data/{user_input}")9.sys.setprofile()/sys.settrace()
危险等级:
风险: 破坏调试器或注入代码
import sys
def malicious_trace(frame, event, arg):
os.system("rm -rf /") # 跟踪时执行恶意代码
sys.settrace(malicious_trace)仅用于可信的调试场景!
10.ctypes调用系统API
危险等级:
风险: 直接操作内存或系统调用
from ctypes import *
libc = CDLL("libc.so.6")
libc.system(b"rm -rf /") # 直接调用系统命令必须进行严格的输入验证!
安全防护黄金法则
- 永远不要信任用户输入:所有输入必须验证、过滤
- 最小权限原则:使用低权限账户运行Python
- 沙箱环境:敏感操作在容器或虚拟机中执行
- 依赖检查:定期审计第三方库(如pip-audit)
# 安全编程模板示例
import ast
import json
def safe_eval(input_str):
try:
return ast.literal_eval(input_str) # 仅允许字面量
except (ValueError, SyntaxError):
return None
user_data = safe_eval('{"key": "value"}') # 安全方式相关推荐
- 国家企业信用信息公示系统湖北
-
首先要确定你输入的登录信息是正确的,主要是看联络员手机号显示的前三位和后三位是否正确,如果正确的话点获取验证码还收不到短信的话,有可能是工商局系统内备案的手机号码中间的某位数是错误的,我出现过同样的问...
- 公积金贷款利率是多少(五年期公积金贷款利率是多少)
-
自2022年10月1日起,公积金贷款利率,手套住房:五年期以下(含五年),贷款利率2.6%,五年期以上3.1%;第二套住房公积金贷款利率,五年期以下(含五年)3.025%,五年期以上3.575%。你好...
- 电脑总自动关机怎么解决(电脑总自动关机怎么办)
-
1、主机散热不良,这是最常见的一种,主要表现为:电脑声音不正常,如风扇转动的声音;主板等配件上有烧焦的痕迹或者闻一闻有烧焦的气味;cpu等主要元器件的温度,如cpu的温度过高等。2、病毒木马的...
- win7激活必须联网吗(win7激活要钱吗)
-
Windows操作系统在安装之后,需要激活才能正常使用。如果没有联网的情况下安装Windows操作系统,可以通过以下两种方法进行激活:1.电话激活:在Windows安装界面选择“电话激活”选项进行激活...
- 有必要买移动硬盘吗
-
1、虽然可以,但是不合算也不适合。 2、固态硬盘相对机械硬盘而言,胜出的是性能,软肋是寿命。 3、目前的硬盘盒大都是USB接口,成了固态硬盘的瓶颈,限制了固态硬盘性能的发挥。而固态硬盘最致命的...
- 移动宽带路由器怎么设置(移动宽带路由器怎么设置桥接模式)
-
1.结论:移动路由器设置过程包括SIM卡安装、路由器连接WiFi和设备、路由器管理界面设置等步骤。2.深入分析:(1)SIM卡安装1确认您购买的移动路由器支持的SIM卡规格,如果未知请咨询销售...
- 笔记本cpu天梯图全系列(笔记本cpu天梯图2020年最新版)
-
麒麟9000>>麒麟9000e>麒麟990>麒麟990e>麒麟980>麒麟985>麒麟820>麒麟820e>麒麟810>麒麟970>麒麟960>麒麟710>大于麒麟710a>麒麟950>麒麟955>...
- 怎么查询家里wifi密码(怎么查询家里wifi密码是多少)
-
一、通过已连接wifi的电脑查看1、找到电脑右下角的无线网图标,就是类似信号的图标,点开;2、然后右键自己的wifi名称,选择“属性”;3、进去之后勾选“显示字符”,然后就可以看见密码框的密码以数字显...
- 分区工具diskgenius怎么合并分区
-
DiskGenius是一款功能全面的磁盘管理工具,其可以帮助我们进行磁盘分区管理,包括创建新分区、删除分区、扩展分区等。如果您想要合并分区到C盘,可以按照以下步骤进行操作:1.打开DiskGeniu...
- windows10易升怎么用(微软windows10易升使用教程)
-
windows10易升是微软官方的。windows10易升是微软官方发布的升级助理或者叫升级助手(官方下载),帮助你升级到win10最新版本,同时也帮助Win7Win8.1用户升级到Windows1...
- 300兆光纤买什么路由器(300兆光纤买3000m的路由器有用吗)
-
对于300Mbps的网速,推荐选择支持AC750及以上的路由器型号。比如TP-LinkArcherC20、D-LinkDIR-816、NetgearR6020等,都是性价比不错的选择。此类路由...
- windows10产品密钥查询(查看windows10产品密钥)
-
要查看电脑上Windows10的产品密钥,你可以按照以下步骤进行操作:打开“开始”菜单,然后点击“设置”图标(齿轮状图标)。在“设置”窗口中,点击“更新和安全”选项。在左侧导航栏中,选择“激活”选项...
- 电脑总死机卡住不动怎么办(电脑老是死机卡住)
-
如果你的电脑经常卡死,而且只能强制关机,别忘了说明电脑这个配置不够造成的,你需要提高一下它的配置,比如说加一个内存条或者换一个固态硬盘,这样才能够正常运行,不然的话这种电脑是没有办法使用的,现在电脑都...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
