热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

8PHP代码审计——thinkphp3.2.3框架信息泄露

环境: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函数的功能非常强大,但也非常危险,在开发中应尽量避免使用数据缓存函数。


推荐阅读
  • 本文详细介绍了在XAMPP环境中如何修改Apache和MySQL的默认端口号,并确保WordPress能够正常访问。同时,提供了针对Go语言社区和Golang开发者的相关建议。 ... [详细]
  • 深入理解 .NET 中的中间件
    中间件是插入到应用程序请求处理管道中的组件,用于处理传入的HTTP请求和响应。它在ASP.NET Core中扮演着至关重要的角色,能够灵活地扩展和自定义应用程序的行为。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 深入理解ThinkPHP5.1自定义标签的应用与实现
    本文详细探讨了ThinkPHP5.1框架中自定义标签的创建与使用方法,包括标签库的建立、模板配置以及在实际项目中的应用技巧。 ... [详细]
  • ThinkPHP框架提供了add方法来实现在数据库表中插入新记录的功能,此方法等效于SQL语句中的INSERT INTO命令。本文将详细介绍add方法的使用方式及其应用场景。 ... [详细]
  • 本文探讨了PHP中使用命名空间和自动加载机制的重要性,特别是在大型项目中,如何有效管理和加载文件,避免代码冗余,提高开发效率。 ... [详细]
  • 本文将详细探讨PHP中C的作用,并对比其他编程语言如Java和C的特点及其适用场景。 ... [详细]
  • ThinkPHP RBAC 实战:登录验证详解
    本文将详细介绍 ThinkPHP 框架中的 RBAC(角色基础访问控制)系统,特别是登录验证部分。我们将通过实际代码示例,展示如何实现用户登录验证、验证码生成及验证、以及登录后的权限管理。 ... [详细]
  • XAMPP 遇到 404 错误:无法找到请求的对象
    在使用 XAMPP 时遇到 404 错误,表示请求的对象未找到。通过详细分析发现,该问题可能由以下原因引起:1. `httpd-vhosts.conf` 文件中的配置路径错误;2. `public` 目录下缺少 `.htaccess` 文件。建议检查并修正这些配置,以确保服务器能够正确识别和访问所需的文件路径。 ... [详细]
  • 本文介绍了ThinkPHP框架的基本概念及其主要特性。作为一款遵循Apache许可证的开源框架,ThinkPHP不仅支持多种平台和Web服务器,还提供了丰富的功能以适应不同的开发需求。 ... [详细]
  • 本文介绍如何使用 PHP 实现对特定 IP 地址或域名的访问控制,包括单个 IP、多个 IP、通配符及 IP 段的支持,并提供详细的代码示例。 ... [详细]
  • 致信息安全爱好者的成长指南
    本文旨在为信息安全爱好者提供一份详尽的成长指南,涵盖从学习心态调整到具体技能提升的各个方面。 ... [详细]
  • 现在的新手程序猿,动不动就是框架,就连外面培训的也是框架,我就问一句,没了框架是不是就啥也不会了 ... [详细]
  • Bootstrap Paginator 分页插件详解与应用
    本文深入探讨了Bootstrap Paginator这款流行的JavaScript分页插件,提供了详细的使用指南和示例代码,旨在帮助开发者更好地理解和利用该工具进行高效的数据展示。 ... [详细]
  • 本文详细介绍了如何在PHP中记录和管理行为日志,包括ThinkPHP框架中的日志记录方法、日志的用途、实现原理以及相关配置。 ... [详细]
author-avatar
闲云野鹤-男主角_185
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有