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

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

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

簡介

在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引擎之外,還存在其他引擎,不同的引擎所對應的session的存儲方式不相同。

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

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

示例代碼如下:

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

存儲機制

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

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

假設(shè)我們的環(huán)境是xampp,那么默認配置如上所述。

在默認配置情況下:

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

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

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

在php_serialize引擎下:

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

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

序列化簡單利用

test.php

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

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

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

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結(jié)合實例形式分析了php實現(xiàn)針對有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實現(xiàn)服務端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實現(xiàn)APP微信支付的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實現(xiàn)的多維數(shù)組排序算法,結(jié)合實例形式對比分析了php針對多維數(shù)組及帶有鍵名的多維數(shù)組進行排序相關(guān)操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要為大家詳細介紹了php結(jié)合ajaxuploadfile實現(xiàn)無刷新文件上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細介紹了PHP開發(fā)接口使用RSA進行加密解密方法,對此有興趣的朋友可以學習下。
主站蜘蛛池模板: 成人免费观看男女羞羞视频 | 成人免费黄色 | 99久久99久久精品国产片果冰 | 色偷偷噜噜噜亚洲男人 | 久久精品一区二 | 欧美日韩高清 | 羞羞色在线观看 | 婷婷一级片| 国产精品久久久久久婷婷天堂 | 国产精品黄 | 91亚洲一区 | 亚洲国产精品一区二区第一页 | 日本一道本视频 | 日韩成人在线播放 | 午夜影院网站 | 亚洲一区二区高清 | 亚洲欧美视频 | 中文一区 | 午夜免费网站 | 国产伦精品一区二区三区精品视频 | 国产一区在线免费观看 | 亚洲福利av | 亚洲精品一区二区三区蜜桃久 | 青青草华人在线视频 | 亚洲精品一区二区冲田杏梨 | 久久精品中文字幕 | 日韩成人精品视频 | 激情国产 | 欧州一区二区三区 | 久久久久九九九女人毛片 | 欧美在线观看一区 | 欧美日韩电影一区二区 | 欧美黑人又粗大 | 国产一在线 | 成人av一区二区三区 | www.色午夜.com| 欧美a在线 | 亚洲中午字幕 | 亚洲免费观看视频 | 91精品国产91久久久久久 | 日日操夜夜操天天操 |