Python 中更安全的 eval
2024-10-19 18:48:53
问题
想要将一段列表形式的字符串转为 list
,但是担心这个动态的字符串可能是恶意的代码?使用 eval
将带来安全隐患。比如:
# 期望是
eval('[1, 2, 3]')
# 实际上是
eval("os.popen('rm -rf *')")
解决方案
使用 ast.literal_eval
可以很好的避免这个问题,该函数可以安全执行仅包含文字的表达式字符串。支持的对象有字符串、字节、数字、元组、列表、字典、集合、 布尔值、None
和 Ellipsis
。这些是可以嵌套的,比如以字典作为元素的列表:
>>> from ast import literal_eval
>>> literal_eval("[{'name': 'john', 'location': 'halo7'}]")
[{'name': 'john', 'location': 'halo7'}]
注意 literal_eval
不可以执行任何复杂的表达式,比如包含运算符或是有索引的表达式都是不支持的,会直接抛出异常。这也保证了它不会执行恶意代码。
拓展
- 使用
literal_eval
时,足够复杂或是巨大的字符串可能导致 Python 解释器的崩溃,因为 Python 的 AST 编译器是有栈深限制的 literal_eval
解析异常时,可能会抛出ValueError
,TypeError
,SyntaxError
,MemoryError
或RecursionError
,这取决于传入的字符串
最新文章
- Oracle 查询语句(where,order by ,like,in,distinct)
- mac下有道词典用不了
- 解决Django和EasyUI搭配使用时出现的CSRF问题
- wampserver,eclipse,PHPeclipse搭建php开发环境
- 拉动滚动条追加内容,无限延伸document高度 $(window).scroll(function(){if($(window).scrollTop() + $(window).height() == $(document).height()) { $(";body";).append(html) } })
- perl 调用方法 子例程说明
- Activity组件的生命周期
- mongodb.conf
- C 小问题集锦
- 【bzoj1552】[Cerc2007]robotic sort
- ●BZOJ 2393 Cirno的完美算数教室
- idea 15安装步骤2017.6.25
- mysql查看索引与锁
- Codeforces.1139D.Steps to One(DP 莫比乌斯反演)
- jmeter在几个固定的字符串中,随机取其中之一的方法
- luogu P2480 [SDOI2010]古代猪文
- revit api 实现过滤墙图元并选中
- 二维RMQ模板
- lseek使用说明
- zabbix snmp 协议监控 dell iRDAC