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

免费软件下载官方网站wordpress网站好做排名吗

免费软件下载官方网站,wordpress网站好做排名吗,哈尔滨做网站公司哪家好,好的家装设计目录 前置知识 字符串逃逸-减少 字符串逃逸-增多 前置知识 1.PHP 在反序列化时,语法是以 ; 作为字段的分隔,以 } 作为结尾,在结束符}之后的任何内容不会影响反序列化的后的结果 class people{ public $namelili; public $age20; } var_du…

目录

前置知识

字符串逃逸-减少

字符串逃逸-增多


前置知识

1.PHP 在反序列化时,语法是; 作为字段的分隔,以 } 作为结尾,结束符}之后的任何内容不会影响反序列化的后的结果

class people{

    public $name='lili';

    public $age='20';


}

var_dump(unserialize('O:6:"people":2:{s:4:"name";s:4:"lil"";s:3:"age";s:2:"20";}123245dasdsf'));

2.根据长度判断内容

'O:6:"people":2:{s:4:"name";s:4:"lil"";s:3:"age";s:2:"20";}其中lil"是name的值

3.其中字符串必须以双引号包裹,不能不写或以单引号包裹; 

注意点,很容易以为序列化后的字符串是;},但对象序列化是直接}结尾

php反序列化字符逃逸,就是通过这个结尾符实现的当长度不对应的时候会出现报错无法完成反序列化

4.什么事字符串逃逸?

就是开发者使用先将对象序列化,然后将序列化后的敏感字符进行过滤或替换,最后再进行反序列化。这个时候就有可能会产生PHP反序列化字符逃逸的漏洞。分为两种情况:

1.字符串减少

O:4:"user":1:{s:8:"username";s:5:"admin";} -->O:4:"user":1:{s:8:"username";s:5:“hack";}

2.字符串增多

O:4:"user":1:{s:8:"username";s:5:"admin";}-->O:4:"user":1:{s:8:"username";s:5:“hacker";}

开发者可能通过这些方法来达到过滤非法字符的目的,但是却会造成其他的问题字符串逃逸

字符串逃逸-减少

<?php
class a{public $name = "abcp";public $number = "1234";
}$data = serialize(new a());
echo '序列化:'.$data."\n";
$data = str_replace("p","",$data);//注意这个str_replace,它把p都替换为空
echo '序列化:'.$data."\n";
var_dump(unserialize($data));

也就是说它过滤了一个p之后,会吞噬一个字符,但是吞噬之后序列化字符串不符合序列化的语法规范,所以使其无法反序列化成功

这样某种程度起到了安全的作用 ,但是如果我们使其吞噬更多内容会不会达到结果合法的目的 

解释:原acbp中p被替换了,abc”成了一个整体,本质上就是把 ” 给吞噬掉了 ,所以有多少个p就好吞噬掉多少个字符

字符串逃逸就事利用吞噬更多的字符,使序列化的字符串与后面的引号形成闭合,从而构造恶意代码,那么吞噬多少算合适呢?一直吞噬到下一个可控点的值之前,使得下一个可控制点的第一个引号充当上一个值的结束引号,可以吞噬,也可以不吞,后面会说。如上面例子有两个变量,通过number值构造恶意代码,就需要吞噬到number的值前面,让该值的第一个引号充当name的结束引号。:

O:1:"a":2:{s:4:"name";s:4:"abc";s:6:"number";s:4:"1234";}

O:1:"a":2:{s:4:"name";s:4:"abc";s:6:"number";s:4:"1234";}

需要注意的是要构造的字符串通常长度是2位数的,所以应该多逃逸一个字符

O:1:"a":2:{s:4:"name";s:?:"abc";s:6:"number";s:xx:"要构造的字符串";}

 

所以要写19+1 个p来逃逸字符

属性之间用一个分号分隔,就可以构造逃逸出来的恶意代码了,如下:

O:1:"a":2:{s:4:"name";s:23:"abc";s:6:"number";s:19:";s:3:"age";i:25;}";}

构造了一个age属性,值为25

而上面提到可以把值前面的引号也吞噬掉,其实是一样的,吞噬掉了,我们在构造的是补回来就可以了 

O:1:"a":2:{s:4:"name";s:4:"abc";s:6:"number";s:4:"1234";}

如果它过滤的时候不止吞噬一个字符怎么办?那样就可能出现不会正好能吞噬到下一个可控变量引号之前的情况 ,如一次吞噬6个

class a{public $name = "abchacker";public $number = '123';
}$data = serialize(new a());
echo '序列化:'.$data."\n";
$data = str_replace("hacker","",$data);
echo '序列化:'.$data."\n";
var_dump(unserialize($data));

这种情况需要把引号吞掉,因为需要在可控变量里补字符,那么通过上面吞一个的例子,我们知道需要吞21个字符,但是21/6也是除不尽的,这时候可以直接往多了吞就好,吞噬24个是可以被出尽的,也就是4个hacker,那么多出来的,在恶意代码中补上3个任意字符给他吞噬就可以了

字符串逃逸-增多

经过替换后,字符串增多,目标使isadmin=1

<?php
class a{public $name = "php123";public $number = '1234';public $isadmin = '0';
}$data = serialize(new a());
echo '序列化:'.$data."\n";
$data = str_replace("php","hack",$data);
echo '序列化:'.$data."\n";
var_dump(unserialize($data));

字符串增多并需要其他的可控的,使吐出的字符结合到一起最终构造成合法的序列化字符串即可

O:1:"a":3:{s:4:"name";s:xx:"hackxxx";s:6:"number";s:4:"1234";s:7:“isadmin";s:1:"1";}

";s:6:"number";s:4:"1234";s:7:"isadmin";s:1:"0";}

xxx表示还不知需要多少个hack

";s:6:"number";s:4:"1234";s:7:“isadmin";s:1:"1";}如果我们使得这串字符被吐出来,那么这样就最终形成了一个合法的序列化字符串

O:1:"a":3:{s:4:"name";s:xx:"hackxxx ";s:6:"number";s:4:"1234";s:7:“isadmin";s:1:"1";}

因为}结束后,后面的";s:6:"number";s:4:"1234";s:7:"isadmin";s:1:"0";}会被丢弃

一个php会被替换成hack一个php吐出一个字符 “;s:6:”number“;s:4:”1234“;s:7:”isadmin“;s:1:”1“;}49个字符,所以需要输入49php 

假设一个php会被替换成hacker一个php吐出三个字符 “;s:6:”number“;s:4:”1234“;s:7:”isadmin“;s:1:”1“;}49个字符49除以3=161,所以需要输入16php同时将“;s:6:”number“;s:4:”1234“;s:7:”isadmin“;s:1:”1“;}改为“;s:6:”number“;s:4:”123“;s:7:”isadmin“;s:1:”1“;}这样就是48个字符,输入16php刚刚好

吐出的多了就在“;s:6:”number“;s:4:”1234“;s:7:”isadmin“;s:1:”1“;}红色部分增加字符即可,如17个php等于吐出51个字符,原49位多出2位,在number补2位即可

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

相关文章:

  • 沈阳做企业网站哪家好河南省新闻出版学校咋样
  • 汕头企业自助建站青海住房和城乡建设部网站
  • 手机商城网站制作专门做画册的网站
  • 体育网站开发的目的上海网站建设外包
  • 响应式网站模板 食品福田欧曼卡车
  • 一个网站建设需要什么牡丹区住房和城乡建设局网站
  • 个人网站备案类型网站建设费用如何收取
  • 品牌网站建设的作用网站做线
  • 芜湖做网站找哪家好怎么自己网站搜不到了
  • 网络公司网站报价方案wordpress文章类插件
  • 公司建设个网站一点空间网站建设
  • 百度公司网站制作个人网站制作 教程
  • 网站备案后可以更换域名吗做网站互联网公司有哪些
  • 中装建设官方网站网站的建设 想法
  • 口碑好的专业网站建设运城姚孟网站建设
  • 网站被封了怎么办设计学习网站
  • 微餐饮网站建设比较好网站建设服务便宜
  • 长沙网页制作设计长春seo网站排名
  • 福建省新特建设工程有限公司网站网站建设主要包括哪两个方面
  • 互联网公司排名情况免费网站优化怎么做
  • 那个网站科四做课时企业网站推广怎么做
  • 湖北疾控最新提醒南京网站关键词优化
  • 中国建筑业协会官方网站检测网站为什么打不开了
  • 西安晨曦e动网站建设在线咨询24小时免费咨询
  • dedecms网站后台管理沈阳网站制作 600元
  • 怎么做导航网站网站开发学习视频
  • 黑龙江省城乡和住房建设厅网站做网站租什么服务器
  • 企业网企业网站制作我市精神文明建设的门户网站
  • 网站上的超链接怎么做wordpress 百度广告插件
  • 建站网站哪个最好wordpress夜间模式插件