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

深入解析PHP中SESSION反序列化機制

這篇文章主要介紹了PHP中SESSION反序列化機制的相關資料,文中介紹的非常相信,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。

簡介

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

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

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

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

  • 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是用來設置session的序列話引擎的,除了默認的PHP引擎之外,還存在其他引擎,不同的引擎所對應的session的存儲方式不相同。

  1. php_binary:存儲方式是,鍵名的長度對應的ASCII字符+鍵名+經過serialize()函數序列化處理的值
  2. php:存儲方式是,鍵名+豎線+經過serialize()函數序列處理的值
  3. php_serialize(php>5.5.4):存儲方式是,經過serialize()函數序列化處理的值

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

示例代碼如下:

<?php
ini_set('session.serialize_handler', 'php_serialize');
session_start();
// do something

存儲機制

php中的session中的內容并不是放在內存中的,而是以文件的方式來存儲的,存儲方式就是由配置項session.save_handler來進行確定的,默認是以文件的方式存儲。

存儲的文件是以sess_sessionid來進行命名的,文件的內容就是session值的序列話之后的內容。

假設我們的環境是xampp,那么默認配置如上所述。

在默認配置情況下:

<?php
session_start()
$_SESSION['name'] = 'spoock';
var_dump();
?>

最后的session的存儲和顯示如下:

可以看到PHPSESSID的值是jo86ud4jfvu81mbg28sl2s56c2,而在xampp/tmp下存儲的文件名是sess_jo86ud4jfvu81mbg28sl2s56c2,文件的內容是name|s:6:"spoock"; 。name是鍵值,s:6:"spoock";serialize("spoock")的結果。

在php_serialize引擎下:

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

SESSION文件的內容是a:1:{s:4:"name";s:6:"spoock";} 。a:1是使用php_serialize進行序列話都會加上。同時使用php_serialize會將session中的key和value都會進行序列化。

在php_binary引擎下:

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

SESSION文件的內容是names:6:"spoock"; 。由于name的長度是4,4在ASCII表中對應的就是EOT。根據php_binary的存儲規則,最后就是names:6:"spoock"; 。(突然發現ASCII的值為4的字符無法在網頁上面顯示,這個大家自行去查ASCII表吧)

序列化簡單利用

test.php

<?php
class syclover{
 var $func="";
 function __construct() {
  $this->func = "phpinfo()";
 }
 function __wakeup(){
  eval($this->func);
 }
}
unserialize($_GET['a']);
?>

在11行對傳入的參數進行了序列化。我們可以通過傳入一個特定的字符串,反序列化為syclover的一個示例,那么就可以執行eval()方法。我們訪問localhost/test.php?a=O:8:"syclover":1:{s:4:"func";s:14:"echo "spoock";";}

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結合實例形式分析了php實現針對有序表插值查找的相關操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實現服務端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實現APP微信支付的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實現的多維數組排序算法,結合實例形式對比分析了php針對多維數組及帶有鍵名的多維數組進行排序相關操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要為大家詳細介紹了php結合ajaxuploadfile實現無刷新文件上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細介紹了PHP開發接口使用RSA進行加密解密方法,對此有興趣的朋友可以學習下。
主站蜘蛛池模板: 日韩精品专区在线影院重磅 | 国产高清久久久 | 亚洲日韩中文字幕一区 | 黄色欧美视频 | 色综合久久久久 | 欧美jizzhd精品欧美巨大免费 | 色婷婷综合久久久久中文一区二区 | 亚洲一区精品在线 | 夜夜骑首页 | 综合一区二区三区 | 精品一区二区在线看 | 天天曰天天曰 | 日韩欧美一区二区在线播放 | 精品国产一区二区三区日日嗨 | 亚洲精品在线免费观看视频 | 国产黄色大片 | 国产69久久精品成人看动漫 | 免费视频久久久久 | 久久久久久影院 | 亚洲综合大片69999 | 天天澡天天狠天天天做 | 欧美 日韩 中文 | 精品一区二区免费视频 | 尤物视频在线免费观看 | 男女激情网 | 国产精品亚洲二区 | 成人国产精品久久久 | 久久精品中文 | 亚洲精品乱码久久久久久按摩观 | 亚洲精品乱码久久久久久蜜桃91 | 成人免费淫片aa视频免费 | 99精品一区二区三区 | 亚洲激情综合 | 久在线观看 | 在线视频中文字幕 | 国产第二页 | 91精品久久久久久久久 | 色av一区 | 国产精品视频不卡 | 日韩中文字幕 | 特级做a爰片毛片免费看108 |