python eval()函数的妙用和滥用

eval()函数十分强大,官方demo解释为:将字符串str当成有效的表达式来求值并返回计算结果:python

>>> s='8*8'
>>> eval(s)
64
>>> eval('2+5*4')
22
>>> x=1
>>> y=4
>>> eval('x+y')
5
>>> eval('98.9')
98.9
>>> eval('9.9\n')
9.9
>>> eval('9.9\n\t\r  \t\r\n')
9.9

  能够把list,tuple,dict和string相互转化:函数

>>> l = "[2,3,4,5]"
>>> ll=eval(l)
>>> ll
[2, 3, 4, 5]
>>> type(ll)
<type 'list'>
>>> d="{'name':'python','age':20}"
>>> dd=eval(d)
>>> type(dd)
<type 'dict'>
>>> dd
{'age': 20, 'name': 'python'}
>>> t='(1,2,3)'
>>> tt=eval(t)
>>> type(tt)
<type 'tuple'>
>>> tt
(1, 2, 3)

  eval()函数功能强大,但也很危险,若程序中有如下语句:.net

s=raw_input('please input:')
print eval(s)

  

下面举几个被恶意用户使用的例子:
1》运行程序,若是用户恶意输入:blog

please input:__import__('os').system('dir')
则eval()以后,当前目录文件都会展示在用户前面。。。字符串

2》运行程序,若是用户恶意输入:input

please input:open('data.py').read()string

若是,当前目录中刚好有一个文件,名为data.py,则恶意用户变读取到了文件中的内容。。。class

3》运行程序,若是用户恶意输入:import

please input:__import__('os').system('del delete.py /q')
若是,当前目录中刚好有一个文件,名为delete.py,则恶意用户删除了该文件。。。
/q :指定静音状态。不提示您确认删除。程序

 

文章参考连接:https://blog.csdn.net/sxingming/article/details/52130663

相关文章
相关标签/搜索