当前位置: 首页 > 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.w-s-a.com/news/666939/

相关文章:

  • 搜搜网站收录广告设计与制作模板图片
  • 江苏省建设监理协会网站汕头网站建设方案优化
  • 中国风网站配色方案正规少儿编程排名
  • 兼职做网站的软件wordpress赞的代码
  • 销售网站的技巧四博互联做的网站
  • 网站建设 图片问题小程序免费制作平台凡科网页版
  • 猪八戒网做网站怎么样网站建设 客户同程
  • 西安网站建设那家强网站建设方案 报价
  • 销售网站建设考核指标网站建设价格组成
  • 网站302跳转网站建设完成后 下一步做什么
  • 赣州制作网站企业硬件开发用什么语言
  • 新网站如何被网站收录百度排名优化软件
  • html网站简易模板国内买机票的网站建设
  • 百度关键词分析工具百度seo排名软
  • 自己怎样做免费网站ueditor 上传wordpress
  • 深圳高端网站开发网站建设公司销售技巧
  • 网站建设的优势是什么意思可拖动网站
  • 建设什么企业网站网站微信认证
  • 网站开发的平台成都有哪些好玩的
  • 上海金瑞建设集团网站怎么创建免费网页
  • 柳州做网站设计的公司制作网站软件下载
  • 湖南seo网站开发苏州网络营销及网站推广
  • 如何发布自己做的网站郑州网站建设定制开发
  • 重庆网站商城宁波网络公司联系方式
  • 个人网站建设实验心得seo课程简介
  • 免费自助建站系统下载推广app网站
  • 用scala做的网站标题关键词优化技巧
  • 百度网站评级wordpress忘记admin
  • 建筑标准下载网站263企业邮箱 登陆
  • 旅游房地产网站建设德保网站建设