当前位置: 首页 > news >正文

营销型网站建设遨龙上海个人建站

营销型网站建设遨龙,上海个人建站,做网站的什么公司最好,马鞍山网站设计价格Web渗透—PHP反序列化 课程学习分享#xff08;课程非本人制作#xff0c;仅提供学习分享#xff09; 靶场下载地址#xff1a;GitHub - mcc0624/php_ser_Class: php反序列化靶场课程#xff0c;基于课程制作的靶场 课程地址#xff1a;PHP反序列化漏洞学习_哔哩…Web渗透—PHP反序列化        课程学习分享课程非本人制作仅提供学习分享 靶场下载地址GitHub - mcc0624/php_ser_Class: php反序列化靶场课程基于课程制作的靶场 课程地址PHP反序列化漏洞学习_哔哩哔_bilibili 七、wakeup和sleep 1.__sleep() 序列化serialize()函数会检查类中是否存在一个魔术方法__sleep()。 如果存在该方法会先被调用然后才执行序列化操作。 此功能可以用于清理对象并返回一个包含对象中所有应被序列化的变量名称的数组。 如果该方法未返回任何内容则NULL被序列化并产生一个E_NOTICE级别的错误。 ?php class User {const SITE  uusama;public $username;public $nickname;private $password;public function __construct($username, $nickname, $password){$this-username  $username;$this-nickname  $nickname;$this-password  $password;}public function __sleep(){return array(username, nickname); //__sleep()执行返回需要序列化的变量名过滤掉password变量} } $user  new User(a, b, c); echo serialize($user); //serialize()只序列化sleep返回的变量 ? 触发时机序列化serialize()之前 功能对象被序列化之前触发返回需要被序列化存储的成员变量删除不必要的属性 参数成员属性return array 返回值需要被序列化存储的成员属性username,nickname 2.__sleep()例题 通过审计代码发现通过benben参数传入的值会赋值传给$cmd而当执行序列化前会先执行__sleep()只返回username成员属性通过system()函数包含所以可以直接传入命令进行执行。 3.__wakeup() unserialize()会检查是否存在一个__wakeup()方法。 如果存在则会先调用__wakeup()方法预先准备对象需要的资源。 预先准备对象资源返回void常用于反序列化操作中重新建立数据库连接或执行其他初始化操作。 __wakeup()在反序列化unserialize()之前__destruct()在反序列化unserialize()之后。 ?php class User {const SITE  uusama;public $username;public $nickname;private $password;private $order;public function __wakeup(){$this-password  $this-username; //反序列化之前触发wakeup给password赋值} } $user_ser  O:4:User:2:{s:8:username;s:1:a;s:8:nickname;s:1:b;}; //字符串中没有定义password var_dump(unserialize($user_ser)); //userialize()结果包含password的值 ? 触发时机反序列化unserialize()之前 功能无 参数无 返回值无包含password的赋值 4.__wakeup() 解题代码 ?php class User {public $username whoami; } $user_ser new User(); echo serialize($user_ser); ?输出结果 O:4:User:1:{s:8:username;s:6:whoami;} 通过审计代码发现通过benben参数传入值会直接赋值给$user_ser并反序列化$user_ser所以我们需要向benben参数内传入序列化值。而反序列化被调用前会先执行__wakeup()调用username成员属性通过system()函数包含所以我们要通过序列化给username成员变量赋值传入系统命令。 八、toString和invoke 1.__toString() 表达方式错误导致魔术方法触发把对象当成字符串调用时触发 常用于构造POP链接 ?php class User {var $benben  this is test!!;public function __toString(){return 格式不对输出不了!;} } $test  new User() ; //把类User实例化宁赋值给$test此时$test是个对象 print_r($test); //调用对象可以使用print_r或者var_dump echo $test; ? 触发时机把对象当成字符串调用 功能无 参数无 返回值无 如果使用echo或者print只能调用字符串的方式去调用对象即把对象当成字符串使用此时自动触发toString() 2.__invoke() 格式表达错误导致魔术方法触发把对象当成函数调用时触发 ?php class User {var $benben  this is test!!;public function __invoke(){echo  它不是个函数!;} } $test  new User() ; //把类User实例化并赋值给$test为对象 echo $test -benben; //正常输出对象里的值benben echo $test() -benben; //加()是把test当成函数test()来调用此时触发invoke() ? 触发时机把对象当成函数调用 功能无 参数无 返回值无
http://www.yutouwan.com/news/424883/

相关文章:

  • 杭州高端网站制作怎么做赛事直播网站
  • 手机网站转换小程序广东省建筑网站
  • 网站策划机构做网站最好的公司
  • excel网站链接怎么做电子商务网站建设策划报告
  • 建筑网站知名度怎么开网店具体流程
  • 宝安最好的网站建设wordpress获取当前文章所属分类
  • php 上传移动到网站根目录wordpress 4.8 rest api
  • 制作一个网站的费用西安网页设计培训费用
  • 做网站工资多少北京开公司的基本流程及费用
  • 网站建设拍金手指排名贰贰seo兼职在家怎么做
  • 打开网上免费网站吗摄影网页制作
  • 珠海仿站定制模板建站网站建设单一来源谈判文件
  • 做个简单的企业小网站如何建设网站教程
  • 公司网站生成二维码开发公司移交物业必备资料
  • icp备案网站信息查询大庆seo公司
  • 做外贸大一点的网站网站建设几点关门
  • 跨国网站浏览器企业免费网站建设模板
  • 模板建站多少钱织梦网站模板响应式
  • 企业为什么要建设电子商务网站和业务多一样的平台
  • 哪个网站可以做微信推送实施网站推广的最终目的
  • 网站建设要多久网站跳出率多少
  • 采购网站模板营销网站设计方案
  • 山西省城乡住房和建设厅网站个人做盈利网站
  • 淘宝网站建设基本流程网站开发网络课程
  • 网站建设与管理教学设计网站项目申报书建设规模
  • 网站名称怎么变更重庆新增10个高风险区
  • 全媒体网站的建设网站响应式建设
  • 视觉营销网站建设规划分析有什么彩票网站做代理好点
  • 网站设计应该做哪些微信小程序官网登陆
  • 后台网站怎么做视频浙江做网站公司