作者:闲云野鹤-男主角_185 | 来源:互联网 | 2023-10-14 19:52
环境:thinkphp_3.2.3_fullphp5.6.27以上下载thinkphp3.2.2解压到http:www.tptest.com网站的根目录下并访问网址&
环境:
thinkphp_3.2.3_full
php5.6.27以上
下载thinkphp3.2.2解压到http://www.tptest.com/网站的根目录下并访问网址,如果出现以下页面,说明安装成功:
找到目录tptest.com\Application\Common\Conf\config.php配置数据库,开启调试,这里只需配置前6项即可,其它均使用默认配置
return array(/* 数据库设置 */'DB_TYPE' => 'mysql', // 数据库类型'DB_HOST' => '127.0.0.1', // 服务器地址'DB_NAME' => 'thinkphp32', // 数据库名'DB_USER' => 'root', // 用户名'DB_PWD' => '123456', // 密码'DB_PORT' => '3306', // 端口'DB_PREFIX' => '', // 数据库表前缀'DB_PARAMS' => array(), // 数据库连接参数'DB_DEBUG' => TRUE, // 数据库调试模式 开启后可以记录SQL日志'DB_FIELDS_CACHE' => true, // 启用字段缓存'DB_CHARSET' => 'utf8', // 数据库编码默认采用utf8'DB_DEPLOY_TYPE' => 0, // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)'DB_RW_SEPARATE' => false, // 数据库读写是否分离 主从式有效'DB_MASTER_NUM' => 1, // 读写分离后 主服务器数量'DB_SLAVE_NO' => '', // 指定从服务器序号'SHOW_PAGE_TRACE'=>true,
);
然后访问网址,如果出现以下页面说明配置完成
thinkphp3.2.2日志文件信息泄露
thinkphp在开启DEBUG调试情况下会在\Application\Runtime\Logs\Home目录下生成日志,在浏览器地址栏中输入路径可以直接访问读取日志文件,输入路径造成目录遍历。
ThinkPHP3.2日志文件路径:Application\Runtime\Logs\Home\17_07_22.log
ThinkPHP3.1日志文件路径:Runtime\Logs\Home\17_07_22.log
可以看到thinkphp的日志文件的格式为:项目名\Runtime\Logs\Home\年份_月份_日期.log,这样容易导致日志文件很容易被猜解到,并且日志里面有执行SQL语句的记录,会导致数据库的相关信息泄露。
通常建议开发阶段开启debug,部署阶段把index.php中的debug模式关闭掉:
define('APP_DEBUG',false);
thinkphp缓存信息泄露
thinkphp提供了方便的缓存方式,包括数据缓存、静态缓存和查询缓存等,主要提供了两个函数进行数据缓存:F函数和S函数,F函数设置缓存数据后没有缓存时间限制,而S函数则可以设置缓存时间。
例如在index.php中通过F函数插入一段代码,访问http://www.tptest.com/网址后,默认会在Application\Runtime\Data目录下生成一个data.php文件
并且data.php文件中的php代码是可以执行的,假设thinkphp中的F函数是可控的,那么攻击者很可能会插入一段恶意的代码向网站写入shell等等,F函数是一个非常危险的函数,需谨慎使用。
在没有设置缓存路径的情况下,F函数缓存的数据默认是在data目录下,S函数默认是在temp目录。
如果使用S函数进行文件方式的缓存机制,那么可以设置DATA_CACHE_KEY参数,避免缓存文件名被猜测到,只需在config.php文件中最下面添加一行配置,例如:'DATA_CACHE_KEY'=>'think'
在index.php中执行S函数,刷新网页,在temp目录下会生成一个md5加密的文件,解密后就是data.php文件了。
F函数和S函数的功能非常强大,但也非常危险,在开发中应尽量避免使用数据缓存函数。