位置: 编程技术 - 正文

ThinkPHP框架安全实现分析(thinkphp框架安装)

编辑:rootadmin

推荐整理分享ThinkPHP框架安全实现分析(thinkphp框架安装),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:thinkphp 安全,thinkphp框架怎么用,thinkphp框架结构,thinkphp5.0框架,thinkphp3.2框架,thinkphp框架作用,thinkphp框架结构,thinkphp框架作用,内容如对您有帮助,希望把文章链接给更多的朋友!

ThinkPHP框架是国内比较流行的PHP框架之一,虽然跟国外的那些个框架没法比,但优点在于,恩,中文手册很全面。最近研究SQL注入,之前用TP框架的时候因为底层提供了安全功能,在开发过程中没怎么考虑安全问题。

一、不得不说的I函数

TP系统提供了I函数用于输入变量的过滤。整个函数主体的意义就是获取各种格式的数据,比如I('get.')、I('post.id'),然后用htmlspecialchars函数(默认情况下)进行处理。

如果需要采用其他的方法进行安全过滤,可以从/ThinkPHP/Conf/convention.php中设置:

从/ThinkPHP/Common/functions.php中可以找到I函数,源码如下:

恩,函数基本分成三块:第一块,获取各种格式的数据。第二块,对获取的数据进行循环编码,不管是二维数组还是三维数组。第三块,也就是倒数第二行,调用了think_filter对数据进行了最后一步的神秘处理。

让我们先来追踪一下think_filter函数:

这个函数很简单,一眼就可以看出来,在一些特定的关键字后面加个空格。

但是这个叫think_filter的函数,仅仅加了一个空格,到底起到了什么过滤的作用?

我们都知道重要的逻辑验证,如验证是否已登录,用户是否能购买某商品等,必须从服务器端验证,如果从前端验证的话,就很容易被绕过。同一个道理,在程序中,in/exp一类的逻辑结构,最好也是由服务器端来控制。

当从传递到服务器端的数据是这样:id[0]=in&id[1]=1,2,3,如果没有think_filter函数的话,会被解析成下表中的1,也就会被当成服务器端逻辑解析。但如果变成如下表2的样子,因为多了一个空格,无法被匹配解析,也就避免了漏洞。

二、SQL注入

相关的文件为:/ThinkPHP/Library/Think/Db.class.php(在3.2.3中改为了/ThinkPHP/Library/Think/Db/Driver.class.php) 以及 /ThinkPHP/Library/Think/Model.class.php。其中Model.class.php文件提供的是curd直接调用的函数,直接对外提供接口,Driver.class.php中的函数被curd操作间接调用。

大概说一下TP的处理思路:

首先将Model类实例化为一个user对象,然后调用user对象中的where函数处理$map,也就是将$map进行一些格式化处理之后赋值给user对象的成员变量$options(如果有其他的连贯操作,也是先赋值给user对象的对应成员变量,而不是直接拼接SQL语句,所以在写连贯操作的时候,无需像拼接SQL语句一样考虑关键字的顺序),接下来调用find函数。

find函数会调用底层的,也就是driver类中的函数——select来获取数据。到了select函数,又是另一个故事了。

select除了要处理curd操作,还要处理pdo绑定,我们这里只关心curd操作,所以在select中调用了buildSelectSql,处理分页信息,并且调用parseSQL按照既定的顺序把SQL语句组装进去。

虽然拼接SQL语句所需要的参数已经全部放在成员变量里了,但是格式不统一,有可能是字符串格式的,有可能是数组格式的,还有可能是TP提供的特殊查询格式,比如:$data['id']=array('gt','');,所以在拼接之前,还要调用各自的处理函数,进行统一的格式化处理。我选取了parseWhere这个复杂的典型来分析。

ThinkPHP框架安全实现分析(thinkphp框架安装)

关于安全方面的,如果用I函数来获取数据,那么会默认进行htmlspecialchars处理,能有效抵御xss攻击,但是对SQL注入没有多大影响。

在过滤有关SQL注入有关的符号的时候,TP的做法很机智:先是按正常逻辑处理用户的输入,然后在最接近最终的SQL语句的parseWhere、parseHaving等函数中进行安全处理。这样的顺序避免了在处理的过程中出现注入。

当然处理的方法是最普通的addslashes,根据死在沙滩上的前浪们说,推荐使用mysql_real_escape_string来进行过滤,但是这个函数只能在已经连接了数据库的前提下使用。

感觉TP在这个地方可以做一下优化,毕竟走到这一步的都是连接了数据库的。

恩,接下来,分析开始:

先说几个Model对象中的成员变量:

where函数的逻辑很简单,如果是where('id=%d&name=%s',array($id,$name))这种格式,那就对$id,$name变量调用mysql里的escapeString进行处理。escapeString的实质是调用mysql_real_escape_string、addslashes等函数进行处理。

最后将分析之后的数组赋值到Model对象的成员函数——$where中供下一步处理。

再分析find函数:

$Pk为主键,$options为表达式参数,本函数的作用就是完善成员变量——options数组,然后调用db层的select函数查询数据,处理后返回数据。

跟进_parseOptions函数:

本函数的结构大概是,先获取了表名,模型名,再对数据进行处理:如果该条数据不在数据库字段内,则做出异常处理或者删除掉该条数据。否则,进行_parseType处理。parseType此处不再跟进,功能为:数据类型检测,强制类型转换包括int,float,bool型的三种数据。

函数运行到此处,就该把处理好的数据传到db层的select函数里了。此时的查询条件$options中的int,float,bool类型的数据都已经进行了强制类型转换,where()函数中的字符串(非数组格式的查询)也进行了addslashes等处理。

继续追踪到select函数,就到了driver对象中了,还是先列举几个有用的成员变量:

版本3.2.3经过改进之后,select精简了不少。parseBind函数是绑定参数,用于pdo查询,此处不表。

buildSelectSql()函数及其后续调用如下:

可以看到,在parseSql中用正则表达式拼接了sql语句,但并没有直接的去处理各种插叙你的数据格式,而是在解析变量的过程中调用了多个函数,此处拿parseWhere举例子。

上面的两个函数很长,我们再精简一些来看:parseWhere首先判断查询数据是不是字符串,如果是字符串,直接返回字符串,否则,遍历查询条件的数组,挨个解析。

由于TP支持_string,_complex之类的特殊查询,调用了parseThinkWhere来处理,对于普通查询,就调用了parseWhereItem。

在各自的处理过程中,都调用了parseValue,追踪一下,其实是用了addslashes来过滤,虽然addslashes在非utf-8编码的页面中会造成宽字节注入,但是如果页面和数据库均正确编码的话,还是没什么问题的。

YII Framework框架教程之使用YIIC快速创建YII应用详解 本文实例讲述了YIIFramework框架使用YIIC快速创建YII应用的方法。分享给大家供大家参考,具体如下:yii提供了强大的命令行工具来快速的创建相关组件和

YII Framework框架使用YIIC快速创建YII应用之migrate用法实例详解 本文实例讲述了YIIFramework框架使用YIIC快速创建YII应用之migrate用法。分享给大家供大家参考,具体如下:yiimigrate查看帮助/*/www/yii_dev/yii/framework#phpyiicmigra

Yii使用migrate命令执行sql语句的方法 本文实例讲述了Yii使用migrate命令执行sql语句的方法。分享给大家供大家参考,具体如下:Yii2自带一个强大的命令行管理工具,在windows下打卡cmd命令窗

标签: thinkphp框架安装

本文链接地址:https://www.jiuchutong.com/biancheng/290960.html 转载请保留说明!

上一篇:YII Framework框架教程之国际化实现方法(yii框架运行原理)

下一篇:YII Framework框架教程之使用YIIC快速创建YII应用详解(yii框架教程)

  • 年度减免税限额
  • 个体户每个月要申报个税吗
  • 税法规定的增值税
  • 怎么计提固定资产折旧科目
  • 临时用工的会计分录
  • 经营范围没广告怎么办
  • 注销公司账面余额要全部清零吗
  • 冲红的专票要给购买方吗
  • 无形资产可以一次性摊销吗?
  • 原材料月末有余额吗
  • 货物和运费一起开票怎么开
  • 待报解预算收入计入什么科目
  • 临时售楼处及其装修费用如何列支
  • 固定资产替换公式
  • 代开运输发票是否预征企业所得税?
  • 原材料供销合同和电子汇划收款回单金额不一样
  • 行政单位维修工程规定
  • 货物运输代理服务税率
  • 软件开发票入研发费用哪个明细科目?
  • 关于工商年检社保的通知
  • 国税局预缴税款在哪里看
  • 小微企业声明函怎么开
  • 1697507434
  • 公司注销了是不是就不能用了
  • 一般纳税人怎么算税
  • php技巧
  • win7系统网络连接出现红叉
  • 广告公司收到广告费发票如何入账
  • unc方式
  • 房产自用或出租什么意思
  • 生产企业外销收入账务处理
  • 逆回购利息计算公式
  • 现代服务业进项税加计扣除申报怎么填
  • 美团收购联联
  • -shared
  • mysql分区语句
  • 差旅费的进项税额需要转出吗
  • 视同销售账务处理如何做?
  • 列入固定资产的金额标准
  • db2udb
  • mongodb cond
  • 企业收到投资款应贷记什么账户
  • 行政事业单位资产报废账务处理
  • 简易计税差额抵扣
  • 金融资产主要包括
  • 跨月的普通发票能作废吗
  • 公司注销前如何先注销工会
  • 电子承兑汇票的承兑人是谁
  • 预收冲应收怎么做账
  • 技术服务类有哪些
  • 什么是挂靠?
  • 开发成本贷方负数表示什么
  • 新会计准则待摊费用还有吗
  • 建筑行业小规模纳税人税率1%
  • fedora29
  • VMware虚拟机中不支持虚拟化
  • 如何恢复ubuntu
  • OS X 10.12.6 beta 1如何更新 OS X 10.12.6 beta 1如何升级
  • sxs.exe病毒
  • linuxcpu监控
  • Linux中cp和scp命令的使用方法
  • cortana可以用于搜索本机文件吗
  • win7任务栏透明调不了
  • win7系统谷歌浏览器错误代码a00a0017
  • win7小技巧
  • windows网慢
  • WIN10补丁无法卸载
  • linux命令行在哪
  • 如何禁用系统
  • 清理ie八
  • 查看进程使用的端口
  • unity全屏
  • etmvc+jQuery EasyUI+combobox多值操作实现角色授权实例
  • js的异步事件循环机制
  • jquery iframe src
  • javascript教程
  • 电子税务局登陆密码在哪里修改
  • 车船税多少钱一辆
  • 湖南省水利建设基金
  • 伴生矿和伴采矿的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设