文章目录 熟悉网站结构确定网站的路由1.通过分析url直接得出路由2.查看app/route.php 了解参数过滤情况SQL注入举例任意文件下载与删除任意文件下载代码分析任意
首先对系统的功能点进行大致的了解,对系统的目录情况进行大致了解,确定ThinkPHP版本


安装页面的url为index.php/install/index/comolete.html
对应的为app下install文件下的controller下的index.php中的comolete方法
index.php对应app目录
install对应install目录
index对应controller下的index.php
comolete.html对应controller下的index.php的comolete方法

首先通过install.lock是否存在判断是否安装
查询数据库中的内容赋值给数组$routeNav和$routeCate
通过循环遍历数组$routeNav和$routeCate中的内容来绑定路由
没带id参数时路由为index/Article/index,带id参数时路由为index/Show/index


此处news的路由为index/Article/index,进入对应的文件Article.php下执行index方法
index方法通过getNID函数获取url上的news字符串,然后根据获取的字符串不同的值展示页面

查看GET、POST等方式的全局过滤情况
THINKPHP全局过滤设置在目录libs/libray/think/Request.php中
在Request.php中查看GET和POST函数内容

解析过滤器函数getFilter,当没有给default设置过滤方式时就会默认使用thinkphp的过滤器

此处find函数进行select查询操作

跟踪find函数,可以看到find函数所在的文件位置在Query.php中

在Query.php文件中查找连接操作数据库的方式
此处用的PDO预编译来执行sql语句
所以当使用的是参数绑定的形式时是不会产生sql注入的

类似这种,将$id进行绑定的方式执行sql语句,是不会产生注入的

此处虽然采用的是PDO预编译,但是$id并没有通过参数绑定的方式传递,而是直接拼接到字符串中
所以还是会产生sql注入的

下载文件处存在目录遍历,可通过../../对任意文件进行下载
在THINKPHP中因为很多文件格式名称都是固定的,所以说可以通过猜解去下载重要文件

通过input获取url中的参数赋值给$name,将当前url地址和$name的值拼接赋值给$file
file_exists函数判断文件是否存在,如果文件存在则进行下载操作
因为此处并没有对特殊符号../进行过滤所以存在目录遍历

与任意文件下载同理

与任意文件下载同理,没有对参数进行过滤,导致可通过../对目录进行回溯

--结束END--
本文标题: 代码审计-8 ThinkPHP框架代码审计 2
本文链接: https://www.lsjlt.com/news/402562.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0