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基础教程之简单入门说明(变量和控制语言使用方法)
Mar 25 Python
使用Python编写一个简单的tic-tac-toe游戏的教程
Apr 16 Python
Python通过poll实现异步IO的方法
Jun 04 Python
Python中线程编程之threading模块的使用详解
Jun 23 Python
Python实现爬虫从网络上下载文档的实例代码
Jun 13 Python
python TKinter获取文本框内容的方法
Oct 11 Python
django 2.2和mysql使用的常见问题
Jul 18 Python
解决Django部署设置Debug=False时xadmin后台管理系统样式丢失
Apr 07 Python
为什么称python为胶水语言
Jun 16 Python
详解Python 中的容器 collections
Aug 17 Python
python中xlutils库用法浅析
Dec 29 Python
python自动化调用百度api解决验证码
Apr 13 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
Windows下PHP的任意文件执行漏洞
2006/10/09 PHP
使用PHP similar text计算两个字符串相似度
2015/11/06 PHP
ArrayList类(增强版)
2007/04/04 Javascript
jQuery 使用手册(六)
2009/09/23 Javascript
JQuery实现表格中相同单元格合并示例代码
2013/06/26 Javascript
javascript递归回溯法解八皇后问题
2015/04/22 Javascript
ES6中如何使用Set和WeakSet
2016/03/10 Javascript
微信小程序 获取微信OpenId详解及实例代码
2016/10/31 Javascript
JavaScript中Array对象用法实例总结
2016/11/29 Javascript
Vue props用法详解(小结)
2018/07/03 Javascript
解决vue+element 键盘回车事件导致页面刷新的问题
2018/08/25 Javascript
JS动画实现回调地狱promise的实例代码详解
2018/11/08 Javascript
vue计算属性get和set用法示例
2019/02/08 Javascript
基于jQuery的时间戳与日期间的转化
2019/06/21 jQuery
python虚拟环境 virtualenv的简单使用
2020/01/21 Javascript
2019最新21个MySQL高频面试题介绍
2020/02/06 Javascript
Vue插槽_特殊特性slot,slot-scope与指令v-slot说明
2020/09/04 Javascript
JavaScript用document.write()输出换行的示例代码
2020/11/26 Javascript
pandas使用get_dummies进行one-hot编码的方法
2018/07/10 Python
Python 2.7中文显示与处理方法
2018/07/16 Python
Python实现模拟浏览器请求及会话保持操作示例
2018/07/30 Python
pycharm 取消默认的右击运行unittest的方法
2018/11/29 Python
python3.4 将16进制转成字符串的实例
2019/06/12 Python
Python实现制度转换(货币,温度,长度)
2019/07/14 Python
python3.5 cv2 获取视频特定帧生成jpg图片
2019/08/28 Python
pycharm软件实现设置自动保存操作
2020/06/08 Python
猫途鹰:全球领先的旅游点评社区
2017/04/07 全球购物
美国伊甸园兄弟种子公司:Eden Brothers
2018/07/01 全球购物
盖尔斯工厂店:GUESS Factory
2020/01/21 全球购物
Java里面有没有全局变量?为什么?
2015/02/06 面试题
医学检验专业大学生求职信
2013/11/18 职场文书
学院书画协会部门岗位职责
2013/12/01 职场文书
优秀少先队辅导员先进事迹材料
2014/05/18 职场文书
2015暑期社会实践个人总结
2015/07/13 职场文书
决心书格式范文
2015/09/23 职场文书
分析SQL窗口函数之聚合窗口函数
2022/04/21 Oracle