当前位置:首页 > 黑客技术 > 正文内容

PHP序列化与反序列化解读

访客4年前 (2021-04-14)黑客技术521

花费了点时刻研讨了下PHP序列化,写在这儿。一是便利自己知识点回忆,二是协助相同有疑问的人,欢迎纠正过错,不喜勿喷.
0×01.确认装备文件
首要体系运用的ubuntu apt-get install方法装置的php5,所以在/etc/php5中两个文件夹中有php.ini 分别为cli与apache2 如下列
指令:
root@ubuntu:/etc/php5# ll -l apache2/ cli/
apache2/:
total 156
drwxr-xr-x 3 root root  4096 Dec 16 19:04 ./
drwxr-xr-x 5 root root  4096 May 28  2019 ../
drwxr-xr-x 2 root root  4096 Jul 14 09:14 conf.d/
-rw-r--r-- 1 root root 69890 Dec 16 19:04 php.ini
-rw-r--r-- 1 root root 69890 Sep 15 13:09 php.ini~
 cli/:
 total 148
drwxr-xr-x 3 root root  4096 Dec 11 17:39 ./
drwxr-xr-x 5 root root  4096 May 28  2019 ../
drwxr-xr-x 2 root root  4096 Jul 14 09:14 conf.d/
-rw-r--r-- 1 root root 69568 Dec 11 17:39 php.ini
-rw-r--r-- 1 root root 69570 Dec 11 17:39 php.ini~
 怎么确认apche2运用了哪个php.ini其实能够经过输出phpinfo 检查到,此处的cli目录中的php.ini装备文件是在指令行时运用的装备文件。
0×02.PHP序列化机制
1. PHP序列化机制
PHP中的装备文件php.ini中含有几项装备项
session.save_path=""   --设置session的存储途径
session_set_save_handler="" --设定用户自界说存储函数,假如想运用PHP内置会话存储机制之外的能够运用本函数(数据库等方法)
session.auto_start   boolen --指定会话模块是否在恳求开始时发动一个会话,默以为0不发动
session.serialize_handler   string --界说用来序列化/反序列化的处理器姓名。默许运用php
-当session.auto_start设置为True的时分或许手动session_start()创立新会话,PHP内部调会调用会话管理器。
- 下面是一段代码其间session_set_save_handler()设置用户自界说会话存储函数。此处仍是运用默许的存储方法以文件方法存储服务器,存储目录与装备文件中php.ini中的session.save_path相关。
- 下面这行代码因未设定序列化处理器的姓名,所以默许运用PHP中内置的序列化处理器(php)。
class FileSessionHandler
{
 private $savePath;
 function open($savePath, $sessionName)
 {
  $this->savePath = $savePath;
  if (!is_dir($this->savePath)) {
   mkdir($this->savePath, 0777);
  }
  echo __FUNCTION__."
";
  return true;
 }
 function close()
 {
  echo __FUNCTION__."
";
  return true;
 }
 function read($id)
 {
  echo __FUNCTION__."
";
  return (string)@file_get_contents("$this->savePath/sess_$id");
 }
 function write($id, $data)
 {
  echo __FUNCTION__."
";
  return file_put_contents("$this->savePath/sess_$id", $data) === false ? false : true;
 }
 function destroy($id)
 {
  $file = "$this->savePath/sess_$id";
  if (file_exists($file)) {
   unlink($file);
  }
  echo __FUNCTION__."
";
  return true;
 }
 function gc($maxlifetime)
 {
  foreach (glob("$this->savePath/sess_*") as $file) {
   if (filemtime($file) + $maxlifetime  time() && file_exists($file)) {
    unlink($file);
   }
  }
  echo __FUNCTION__."
";
  return true;
 }
 function end(){
  echo 'Script end then call register_shutdown_functiond'."
";
 }
}
$handler = new FileSessionHandler();
session_set_save_handler(
array($handler, 'open'),
array($handler, 'close'),
array($handler, 'read'),
array($handler, 'write'),
array($handler, 'destroy'),
array($handler, 'gc')
);
// 下面这行代码能够避免运用目标作为会话保存管理器时或许引发的非预期行为
register_shutdown_function(array($handler,end));
session_start();
上面代码履行的成果为
open
read
Script end then call register_shutdown_functiond
write
close
然后检查session.seve_path中的值,相应的目录能够看到如下相似文件
sess_fifslo9a7j78bv8koc0k4g0lk2 
sess_p4g23nl7mi7od8uohtpojd42b5
其间sess_后边的一串数值便是浏览器中的sessionid数值,翻开相对应的session文件(sess_fifslo9a7j78bv8koc0k4g0lk2 )可检查其内容发现如下:
name|s:2:"tb";
能够发现其为序列化之后的内容,当浏览器带着sessionid再次拜访脚本时,服务器端依据sessionid读取session文件并将其反序列化.
简略总结一下以上代码:
  其实便是经过session_start()手动创立新的会话,会话运用PHP内置序列化方法(php.ini中默许session.serialize_handler为php),经过session_set_save_handler()设定的方法进行存储
0×03.序列化引发的缝隙
PHP中有三种序列化方法
| 处理器         | 对应的存储格局    |

[1] [2]  黑客接单网

扫描二维码推送至手机访问。

版权声明:本文由黑客接单发布,如需转载请注明出处。

本文链接:http://therlest.com/106070.html

分享给朋友:

“PHP序列化与反序列化解读” 的相关文章

接单的黑客_可以找黑客黑美团吗

有在网络安全范畴中,猜测网络违法和歹意软件发展趋势好像现已成为了各大网络安全公司的传统了。 为了防止让咱们去阅览上百页的安全陈述,咱们专门整兼并总结了McAfee、Forrester、FiskIQ、卡巴斯基实验室【1、2、3】、WatchGuard、Nuvias、FireEye、CyberArk、F...

奶牛多少钱一头2021年奶牛价格,2021年奶牛市场行情

字体:大中小,一般不超过200斤重的奶牛,怀孕母牛价格要稍贵一些,一般小点的,优质纯种荷斯坦奶牛,见效慢,关闭窗口,通常3-8个月小。 月的奶牛奶牛,花色、请问一头一头半成年奶牛多少钱!但我家不像你那个样子.荷斯坦奶牛、年龄大小。 来源、厘米,他的特点是投资巨大,理性回归2005-09-1511:5...

宏观经济学价格效应 「经济学传递效应」

饮水机效应,价格效应可分解为替代效应和收入效应。通货膨胀的经济效应主要有两个方面,中提出了著名的“节约悖论,比如买切糕,1元钱买了一块切糕,2,利息和货币通论,微观经济学中的价格效应中的一个问题。 “挤出”效应,政府购买和转移支付对我们经济的影响,加剧了收入分配的不均等化进一步加剧。微观经济学,即不...

Webshell安全检测篇

0x00 依据流量的检测办法 1.概述 笔者一直在重视webshell的安全剖析,最近就这段时刻的心得体会和咱们做个共享。 webshell一般有三种检测办法: 依据流量方法 依据agent方法(本质是直接剖析webshell文件) 依据日志剖析方法 Webshell的分...

如何查询酒店开房记录?谁可以查?网上怎么查?

关于酒店开房记录,这个基本上是看不到的,只有公检法系统(主要是公安局)才能查询的。如果你真想查询,要提供相关真实的身份证明,到公安局咨询,可能需要繁琐的手续。 2014年初,网上就有过“2000W开房数据泄露”的惊爆新闻,是因众多酒店使用了浙江慧达驿站公司开发的酒店Wi-Fi管理、认证系统,而该公司...

如何寻找黑客微信号(只有一个微信号,黑客可以查到对方吗)

一、如何寻找黑客微信号(只有一个微信号,黑客可以查到对方吗) 1、有黑客能查到微信聊天记录是骗人的吗绝对是骗子,请勿相信! 微信聊天信息保存在本地 一般聊天信息都是保存在本地的,除非开通会员可以将聊天信息存储。 黑客查找出来的微信聊天截图是真的吗在手机端启动微信,在微信主界面底部导航中点击“微信”...

评论列表

冬马猫卆
2年前 (2022-06-07)

.ini 分别为cli与apache2 如下列指令:root@ubuntu:/etc/php5# ll -l apache2/ cli/apache2/:total 156drwxr-xr-x 3 root root  4096 Dec 16 19:04 ./d

弦久娇痞
2年前 (2022-06-07)

r-- 1 root root 69568 Dec 11 17:39 php.ini-rw-r--r-- 1 root root 69570 Dec 11 17:39 php.ini~ 怎么确认apche2运用了哪个php.ini其实能够经过输出

只酷寒洲
2年前 (2022-06-07)

etime) {  foreach (glob("$this->savePath/sess_*") as $file) {   if (filemtime($file) + $maxlifetime  time() && file

森槿织谜
2年前 (2022-06-07)

中有php.ini 分别为cli与apache2 如下列指令:root@ubuntu:/etc/php5# ll -l apache2/ cli/apache2/:total 156drwxr-xr-x 3 root root  4096 Dec 16

澄萌雾敛
2年前 (2022-06-07)

_path相关。- 下面这行代码因未设定序列化处理器的姓名,所以默许运用PHP中内置的序列化处理器(php)。class FileSessionHandler{ pr

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。