位置: 编程技术 - 正文

深入讲解PHP的对象注入(Object Injection)(深入理解php内核pdf)

编辑:rootadmin

推荐整理分享深入讲解PHP的对象注入(Object Injection)(深入理解php内核pdf),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入讲解php的对象是什么,深入讲解php的对话框在哪,细说php,php深度分析,深入理解php:高级技巧,php的了解,php的了解,深入讲解php的对象是什么,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

虽然这篇文章叫做PHP对象注入,但是本质上还是和PHP的序列化的不正确使用有关。如果你阅读了PHP中的SESSION反序列化机制对序列化就会有一个大致的认识。PHP对象注入其实本质上也是由于序列化引起的。

基础知识

在php类中可能会存在一些叫做魔术函数(magic 函数),这些函数会在类进行某些事件的时候自动触发,例如__construct()会在一个对象被创建时调用, __destruct()会在一个对象销毁时调用, __toString当对象被当做一个字符串的时候被调用。常见的魔术函数有__construct() 、 __destruct() 、 __toString() 、 __sleep() 、 __wakeup() 。

举例如下:

原理

为什么会用到序列话这样的方法?主要就是就是方便进行数据的传输,并且数据恢复之后,数据的属性还不会发生变化。例如,将一个对象反序列化之后,还是保存了这个对象的所有的信息。同时还可以将序列化的值保存在文件中,这样需要用的时候就可以直接从文件中读取数据然后进行反序列化就可以了。在PHP使用serialize()和unserialize()来进行序列化和反序列化的。

而序列化的危害就在于如果序列化的内容是用户可控的,那么用户就可以注入精心构造的payload。当进行发序列化的时候就有可能会出发对象中的一些魔术方法,造成意想不到的危害。

对象注入

本质上serialize()和unserialize()在PHP内部实现上是没有漏洞的,漏洞的主要产生是由于应用程序在处理对象、魔术函数以及序列化相关问题的时候导致的。

如果在一个程序中,一个类用于临时将日志存储进某个文件中,当__destruct()方法被调用时,日志文件被删除。

代码大致如下:

logfile.php

在其他类中使用LogClass

logLogin.php

上面的这段代码就是一个正常的使用LogClass类来完成日志记录的功能。

下面显示的是存在对象注入漏洞的使用例子。

news.php

深入讲解PHP的对象注入(Object Injection)(深入理解php内核pdf)

上面显示的代码使用了LogClass对象同时还会从用户那里接受输入进行发序列化转化为一个User对象。

当我们提交如下的数据

这样的语句是可以正常使用的,也是程序员希望使用的方法。

但是如果提交的数据为:

那么最后就会输出delete .htaccess。

可以看到通过构造的数据,导致执行了LogClass中的__destruct()方法然后删除了网站中重要的配置文件。

从上面这个例子也可以看出来,如果没有严格控制用户的输入同时对用户的输入进行了反序列化的操作,那么就有可能会实现代码执行的漏洞。

注入点

PHP对象注入一般在处在程序的逻辑上面。例如一个User类定义了__toString()用来进行格式化输出,但是也存在File类定义了__toString()方法读取文件内容然后进行显示,那么攻击者就有可能通过User类的反序列化构造一个File类来读取网站的配置文件。

user.php

正常情况下我们应该传入UserClass序列化的字符串,例如user.php&#;usr=O:9:"UserClass":2:{s:3:"age";i:;s:4:"name";s:3:"Tom";} ,页面最后就会输出User Tom is years old. 。

这也是一个理想的使用方法。

但是如果我们传入的数据为user.php&#;usr=O:9:"FileClass":1:{s:8:"filename";s::"config.php";} ,页面最后的输出是filename发生了变化==>config.php,执行了FileClass中的__toString()方法。

这样就可以读取到config.php中的源代码了。

漏洞挖掘

这类洞一般都是很难挖掘的,虽然显示看起来很简单,但实际上需要的条件还是相当的苛刻的,而且找对象注入的漏洞一般都是通过审计源代码的方式来进行寻找,看unserialize()的参数是否是可控的,是否存在反序列化其他参数对象的可能。

防御

要对程序中的各种边界条件进行测试

避免用户对于unserialize()参数是可控的,可以考虑使用json_decode方法来进行传参。

总结

标签: 深入理解php内核pdf

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

上一篇:深入解析PHP中SESSION反序列化机制(phpseclib)

下一篇:几行代码轻松实现PHP文件打包下载zip(教你一行代码)

  • 个人所得税汇算表
  • 开私家车出差如何报销差旅费
  • 发票盖了财务专用章旁边再盖发票章
  • 外经证错了已经交了税怎么办
  • 财务费用属于什么科目借贷方向
  • 生育津贴需要连续缴纳社保满一年吗
  • 外贸企业当月没交税
  • 预支差旅费属于什么凭证
  • 单位投资非盈利性组织怎样核算
  • 生产过程中产品的质量保证体系
  • 代开专票作废了扣了两次税怎么办?
  • 收到合同款
  • 驻外人员医保报销
  • 销售原材料收到商业承兑汇票会计分录
  • 违约金 罚款
  • 车辆租赁费可以一次性计入费用吗
  • 如何看发票是否被抵扣
  • 税收编码选错了,发票已经开出去几个月了,还有影响吗
  • 税控盘怎么使用
  • 收到住房补贴怎么做账
  • 购房时收取的卖方费用
  • 简易计税开票开成了一般计税的税率会比对不通过吗
  • 汽车租凭发票税率
  • 过路费可以抵税吗
  • 应收账款贷方余额怎么在资产负债表中填列
  • 办公室椅子固定
  • 电脑每次开机都要选择系统怎么办
  • 保总保安服务有限公司
  • 企业向银行申请办理非原路的服务贸易退汇,银行应当
  • 涉税专业服务机构是什么
  • 公证处会计分录
  • 担保余值计算公式
  • 增值税专用发票丢了怎么补救
  • 非贸付汇代扣代交哪些税
  • 视频监控接入方式有哪几种
  • 计算机视觉项目文档
  • 新手入门指南
  • 个体工商户的酒店增值税率是多少
  • 累计预扣法的适用条件
  • python解密加密文件
  • 当月已付款, 没收到发票怎么做账
  • 暂估入库有风险吗
  • 小规模纳税人应交增值税明细科目
  • 结转成本时库存商品是负数
  • 固定资产提取折旧最新规定
  • 出租机械设备
  • 什么是建筑服务的甲供工程
  • 职工教育经费能开专票吗
  • 收到代理服务费怎么做分录呢
  • 销项税票怎么开
  • 盘盈的固定资产怎么处理
  • 政府奖励企业如何领取
  • 总公司是否可以注销分公司
  • 内账价税分离如何做账
  • 事业单位不允许办企业是哪个文件要求的
  • mysql必知必会读后感2000字
  • 如何防止mysql数据库攻击
  • 检查sql脚本语法
  • MySQL利用大数据技术进行回归模型的构建流程
  • mysql的密码忘了该怎么办
  • w10 2021年更新
  • 如何在百度上发布自己的广告
  • freebsd 安装
  • wwSecure.exe - wwSecure是什么进程
  • windows xp无法更改密码
  • win7怎么更改电脑名字
  • mac terminal在哪里
  • rsync windows linux
  • linux打成zip包
  • 各种linux系统比较
  • dos批处理命令大全
  • excel表格布局
  • jquery怎么获取
  • 我的世界服务器怎么创建
  • 抚州到崇仁火车时刻表
  • 境外付款需要什么手续
  • 财税库银是什么费用
  • 云南省国家税务总局
  • 核定征收申报表填写
  • 汽车燃油税每年要交吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设