PHP session advanced_PHP tutorial
php session advanced
This article mainly explains the advanced usage of session
Advanced session configuration in the php.ini configuration file:
session.save_path: session save address (original path: C:/Users/ADMINI~1/AppData/Local/Temp)
session_name: The name obtained by session
session.use_trans_sid: Enable SID support
session.gc_maxlifetime: Garbage collector, specifies the number of seconds after which data will be considered garbage and cleared
session.gc_probability=1
session.gc_divisor=100
The combination of these two is the probability of starting the gc process management
During initialization (session_start())
Probability=session.gc_probability/session.gc_divisor
session.use_cookie = 1: Whether to use cookies
session.cookie_path = '/': Cookie saving path
session.cookie_domain = '': Generally no need to change
session.cookie_lifetime = 0: long storage time
session.save_handler = files: Use files to save session information, change to user
session.save_handler=memcache: If it is memcache, then save_path=tcp://localhost:11211
1. First, change the value of session.save_handler to user (originally files) in the configuration file, and change the session data saving path to the D drive
2. Create relevant files in the root directory
session.php is a public header file, one.php is a session registration event file, two.php is a test file, and three.php is a logout file
one.php:
<!--?php include "session.php"; $_SESSION["isLogin3"]=1; $_SESSION["username"]="admin"; $_SESSION["uid"]=333; echo session_name().'='.session_id()."<br-->";
two.php:
<!--?php include "session.php"; print_r($_SESSION); echo '<br-->'; echo session_name().'='.session_id()." ";
three.php:
<!--?php include "session.php"; $_SESSION=array(); if(isset($_COOKIE[session_name()])){ setCookie(session_name(),'',time()-100,'/'); } session_destroy(); echo session_name().'='.session_id()."<br-->";
It is relatively important for the public header file session.php. Before doing this, in the configuration file must be changed and the value of session.serialize_handler = file must be changed to user
session.php To use the session_set_save_handler() function, check the manual for the parameters used, and then open the session
session_set_save_handler("open","close","read","write","destroy","gc"); session_start();
Then write each method according to the parameters. The focus is to grasp the execution time of each function.
open():
//在运行session_start()是调用,读取session到$_SESSION中 function open($save_path, $session_name){ global $sess_save_path; //将保存路径设置为全局变量 $sess_save_path=$save_path; //读取的路径给保存路径 return true; }
close():
//session_wirte_close()和session_destroy() function close(){ return true; }
read():
//session_start(),$_SESSION //自动把session_id传进来 function read($id){ global $sess_save_path; $sess_file=$sess_save_path."/kf_".$id; return (string)@file_get_contents($sess_file); }
write():
//脚本结束时和使用session_write_close()强制提交SESSION数据时 //直接调用$_SESSION[]="aaa"; function write($id, $sess_data){ global $sess_save_path; //定义保存文件及文件名 $sess_file=$sess_save_path."/kf_".$id; if($fp=@fopen($sess_file, "w")){ $return=fwrite($fp, $sess_data); fclose($fp); return $return; }else{ return false; } }
story() and gc(): (deletion and garbage collection)
//session_destroy()时 function destroy($id){ global $sess_save_path; $sess_file=$sess_save_path."/kf_".$id; //删除路径对象的文件 return @unlink($sess_file); } //session.gc_probability和session.gc_divisor决定的,在open()和read()读数据时, function gc($maxlifetime){ global $sess_save_path; //所有过期的都要删除 //glob遍历出所有以"/kf"的文件作为每一个文件 foreach(glob($sess_save_path."/kf_*") as $filename){ if(filetime($filename)+$maxlifetime < time()){ @unlink($filename); echo $filename; } } return true; }

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

The enumeration function in PHP8.1 enhances the clarity and type safety of the code by defining named constants. 1) Enumerations can be integers, strings or objects, improving code readability and type safety. 2) Enumeration is based on class and supports object-oriented features such as traversal and reflection. 3) Enumeration can be used for comparison and assignment to ensure type safety. 4) Enumeration supports adding methods to implement complex logic. 5) Strict type checking and error handling can avoid common errors. 6) Enumeration reduces magic value and improves maintainability, but pay attention to performance optimization.

How to debug CLI mode in PHPStorm? When developing with PHPStorm, sometimes we need to debug PHP in command line interface (CLI) mode...

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.
