Python之eval()函数危险性浅析


Posted in Python onJuly 03, 2014

一般来说Python的eval()函数可以把字符串“123”变成数字类型的123,但是PP3E上说它很危险,还可以执行其他命令!

对此进行一些试验。果然,如果python写的cgi程序中如果使用eval()而非int()来转换诸如年龄这样的输入框中的内容时是非常危险的。不仅可以看见列出系统的全部文件,还可以执行删除文件,察看文件源代码等危险操作!

试着写了个程序,想把本地的脚本文件同过这样的形式一行一行的写到服务器的某个文件里,可最后失败在无法输入换行符"/n",在提交的语句里只要有换行符,就会出现EOL的出错提示,换了编码方式还是没能成功。
 
网页里有一个提交名字的窗口,这里只是以改它为例,否则名字是不会用eval函数转换的,不过年龄到是很容易出问题。这个文件(http://localhost/tutor4.html)导入了os。

line1 = "Hello, %s." % eval(form['user'].value)

(1)

os.system('del * /q') #删除当前目录下所有文件(不包括文件夹)。

os.system调用当前系统的命令(如windows)

/q
指定强制状态。不提示您确认删除。

(2)若删除文件夹,使用rmdir

/s
删除指定目录和所有子目录以及包含的所有文件。使用 /s 来删除目录树。

/q
在安静模式中运行 rmdir。不经确认即删除目录。

os.system('rmdir d:/workspace /s/q')

(3)列出所有文件os.system('dir')。因为成功执行了dir命令后,系统返回0,所以看到的返回内容只能是Hello,0.而在服务器上,倒是真的列出来了,如果有日志,可能被发现。提交os.system('dir >dir.txt'),那么访问http://localhost/dir.txt那么所有的文件和文件夹都暴露了,想看源代码吗?如果再使用os.system('type target.py').命令如果成功完成同样会返回Hello, 0.的。难道再放进一个文件,再访问那个文件吗?open('target.py').read()

由此,可以在列出和察看其他文件夹里面的内容了。

如果没干别的坏事,那么可删除dir.txt以免被人发现了。os.system('del dir.txt /q')

导入os并执行命令:

__import__('os').system('dir >dir.txt')
Python 相关文章推荐
Python入门篇之字符串
Oct 17 Python
Django自定义插件实现网站登录验证码功能
Apr 19 Python
Python多层装饰器用法实例分析
Feb 09 Python
python 字符串和整数的转换方法
Jun 25 Python
Python3.7实现中控考勤机自动连接
Aug 28 Python
Python面向对象程序设计示例小结
Jan 30 Python
深入浅析Python 中 is 语法带来的误解
May 07 Python
python KNN算法实现鸢尾花数据集分类
Oct 24 Python
Python3 使用map()批量的转换数据类型,如str转float的实现
Nov 29 Python
使用python和pygame制作挡板弹球游戏
Dec 03 Python
解决pytorch 的state_dict()拷贝问题
Mar 03 Python
如何利用python实现Simhash算法
Jun 28 Python
python的绘图工具matplotlib使用实例
Jul 03 #Python
python绘图库Matplotlib的安装
Jul 03 #Python
Python实现全局变量的两个解决方法
Jul 03 #Python
Python实现端口复用实例代码
Jul 03 #Python
在 Django/Flask 开发服务器上使用 HTTPS
Jul 03 #Python
采用python实现简单QQ单用户机器人的方法
Jul 03 #Python
centos系统升级python 2.7.3
Jul 03 #Python
You might like
php开启安全模式后禁用的函数集合
2011/06/26 PHP
在Mac OS上搭建PHP的Yii框架及相关测试环境
2016/02/14 PHP
浅谈php常用的7大框架的优缺点
2020/07/20 PHP
jquery实现人性化的有选择性禁用鼠标右键
2014/06/30 Javascript
jquery.mobile 共同布局遇到的问题小结
2015/02/10 Javascript
Javascript URI 解析介绍
2015/03/15 Javascript
jquery实现在网页指定区域显示自定义右键菜单效果
2015/08/25 Javascript
JavaScript实现的SHA-1加密算法完整实例
2016/02/02 Javascript
完美解决IE不支持Data.parse()的问题
2016/11/24 Javascript
微信小程序 页面之间传参实例详解
2017/01/13 Javascript
node.js入门学习之url模块
2017/02/25 Javascript
JS 组件系列之 bootstrap treegrid 组件封装过程
2017/04/28 Javascript
Element-ui table中过滤条件变更表格内容的方法
2018/03/02 Javascript
JavaScript解析JSON数据示例
2019/07/16 Javascript
解决微信小程序中的滚动穿透问题
2019/09/16 Javascript
element-ui中按需引入的实现
2019/12/25 Javascript
extjs图表绘制之条形图实现方法分析
2020/03/06 Javascript
将Python代码嵌入C++程序进行编写的实例
2015/07/31 Python
python读取txt文件,去掉空格计算每行长度的方法
2018/12/20 Python
django实现更改数据库某个字段以及字段段内数据
2020/03/31 Python
Python通过文本和图片生成词云图
2020/05/21 Python
Python单元测试及unittest框架用法实例解析
2020/07/09 Python
如何用Python进行时间序列分解和预测
2021/03/01 Python
美国知名运动产品零售商:Foot Locker
2016/07/23 全球购物
美国存储和组织商店:The Container Store
2017/08/16 全球购物
全球最大的在线旅游公司:Expedia
2017/11/16 全球购物
澳大利亚拥有最佳跳伞降落点和最好服务的跳伞项目运营商:Skydive Australia
2018/03/05 全球购物
Hotels.com韩国:海外国内旅行所需的酒店和住宿预订网站
2020/05/08 全球购物
大学生就业推荐信范文
2013/11/29 职场文书
学生党员思想汇报范文
2014/01/09 职场文书
网上卖盒饭创业计划书
2014/01/26 职场文书
学校关爱留守儿童活动方案
2014/08/27 职场文书
2014旅游局领导班子四风问题对照检查材料思想汇报
2014/09/19 职场文书
材料员岗位职责范本
2015/04/11 职场文书
安全生产奖惩制度
2015/08/06 职场文书
离职员工给领导和同事的感谢信
2015/11/03 职场文书