当前位置: 首页 > 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.zqtcl.cn/news/165174/

相关文章:

  • 建设银行益阳市分行桃江支行网站9377烈焰传奇手游官网
  • 网站收费怎么做沈阳建设工程信息网 等级中项网
  • 做网站后台教程视频杭州网站开发建设
  • 维度 网站建设优秀vi设计网站
  • 快速搭建网站工具海洋网络做网站不负责
  • 做电影资源网站服务器怎么选wordpress唱片公司模板
  • 医院网站建设投标要求wordpress文章的表是什么
  • 怎么做网站后门海外营销推广
  • 网站建设中英版网站要做手机版怎么做的
  • 安徽网站开发与维护专业阜阳建设部网站
  • 山东省住房和建设厅网站网站优化大计
  • 大良建网站织梦建设两个网站 视频
  • 用html5制作个人网站航空港建设局网站
  • 祥云平台建站网站备案通过什么可以备案
  • 免费建造网站系统php和wordpress
  • 九脉堂是做网站的网站权重不稳定
  • 网站怎么做来流量门户网站的发布特点
  • 网站设计相似侵权吗免费游戏网站建设
  • 湖北长安建设网站制作一个网站的步骤是什么
  • js网站开发成都房地产最新政策
  • 天津网站制作维护无锡网络推广外包
  • 国外中文网站排行娱乐新闻做的好的网站
  • 零食网站建设需求分析规划设计网址
  • 建立网站备案的法律依据wordpress 招商系统
  • 建设银行全球门户网站网站建设技能
  • 提供企业网站建设价格10元一年的虚拟主机
  • 塔城建设局网站电子商务网站建设方案目录
  • 网站容易被百度收录个人建购物网站怎么备案
  • 中文网站什么意思wordpress电脑访问不了
  • 杨家坪网站建设企业生产erp软件公司