search

Session control in PHP

Apr 09, 2018 pm 04:07 PM
phpsessioncontrol

The content of this article is to share with you the painting control in PHP. Friends in need can refer to it

Session Control

HTTP protocol is the mutual communication between WEB server and browser protocol, it is a stateless protocol, that is, each HTTP request is independent of each other. Therefore, the HTTP protocol does not have a built-in mechanism to maintain state between two transactions. For example, when a user requests one page and then requests another page, HTTP will not be able to tell us whether the two requests came from the same user.

In the website, we often need to track a variable: by tracking the variable, we can establish a connection between multiple request things, and then display different content and different pages based on authorization and user identity. This is session control technology.

Commonly used session control technologies include Cookie and Session. Simply put, Cookie determines the user's identity by recording information on the client side; Session determines the user's identity by recording information on the server side.

Cookie is a small text file that is included in the HTTP request message and passed between the web server and the browser. The working principle of Cookie is as follows:

  1. The server sets a Set-Cookie field in the HTTP response message and puts the Cookie data in the Set- The Cookie field is transmitted to the browser along with the HTTP message;

  2. After receiving the HTTP response message, the browser checks Set-Cookie If the field has a value, a Cookie file will be created locally to save the data;

  3. When the browser sends a request to the server again, the browser will first search for the locally saved Cookie file. If If there are any cookies related to the URL being connected in the Cookie file, set a Cookie field in the HTTP request message, add the data in the Cookie file to the field, and finally add the HTTP request message carrying the Cookie field. sent to the server.

Cookies can be used to save user names, passwords, personalized settings and other simple information. The following are instructions for using cookies:

Create
<?php
setcookie("Cookie", "cookievalue", time()+3600);
setcookie() must be called before the content of the HTML file is output
Receive
<?php
echo $_COOKIE["Cookie"];
Delete
<?php
#方法一:将值设为空
setcookie("Cookie", null);

#方法二:将过期时间设为过去时间
setcookie("Cookie", "value" , time());

Session

Session is to maintain the user on the server side A method of session data that works as follows:

  1. When the browser accesses a PHP script for the first time, the seesion_start() function creates a unique Session ID (each client has a unique identification), and automatically saves this Session ID to the client cookie through the HTTP response header. At the same time, a file named with Session ID is also created on the server side to save the user's session information;

  2. When the same user visits this website again, it will automatically pass HTTP The request header brings the Seesion ID saved in the Cookie;

  3. The server PHP script receives the client request, and then the session_start() function will not Then assign a new Session ID, but search the server's hard disk for a Session file with the same name as the Session ID, and read out the session information previously saved for this user.

First of all, there are two ways to create a Session unique identifier: through Cookie or GET. By default, PHP will create a Cookie named PHPSESSID (the value of session.name can be modified through php.ini). If the client disables cookies, you can specify to pass the Session ID through GET. Go to the server (modify parameters such as session.use_trans_sid in php.ini). Secondly, Session is saved in the form of a file. There is a configuration item --session.save_path= "" in php.ini. The path filled in will save all Session files. The naming format of the Session file is: sess_[value of PHPSESSID]. Each file stores the data of a session. Finally, the data saved in the Session file is serialized, such as:

cityID|i:0;cityName|s:3:"all";fanwe_lang|s:5:"zh-cn";fanwe_currency|a:4:{s:2:"id";s:1:"1";s:6:"name_1";s:9:"人民币";s:4:"unit";s:3:"¥";s:5:"radio";s:6:"1.0000";}_fanwe_hash__|s:32:"77c18770c6cb5d89444c407aaa3e8477";

Session can also be used to save some simple information such as user name, password, personalized settings, etc. The following is the use of Session Description:

Create
//启动 session
session_start();

//注册session变量,赋值为一个用户的名称
$_SESSION["username"] = "jochen";

//注册session变量,赋值为一个用户的ID
$_SESSION["uid"] = 1;
Note: session_start() must be called before the content of the HTML file is output
Read
<?php
session_start();
echo $_SESSION["username"]; # # jochen
echo $_SESSION["uid"];      # 1
Destroy
<?php
session_start();
 
unset($_SESSION["username"]);
unset($_SESSION["uid"]);
It should be noted that when there are many session files, I/Q read and write performance problems will occur. At this time, caching systems such as memcached and redis can be used.

Related recommendations:

PHP Learning Array


The above is the detailed content of Session control in PHP. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Explain the concept of a PHP session in simple terms.Explain the concept of a PHP session in simple terms.Apr 26, 2025 am 12:09 AM

PHPsessionstrackuserdataacrossmultiplepagerequestsusingauniqueIDstoredinacookie.Here'showtomanagethemeffectively:1)Startasessionwithsession_start()andstoredatain$_SESSION.2)RegeneratethesessionIDafterloginwithsession_regenerate_id(true)topreventsessi

How do you loop through all the values stored in a PHP session?How do you loop through all the values stored in a PHP session?Apr 26, 2025 am 12:06 AM

In PHP, iterating through session data can be achieved through the following steps: 1. Start the session using session_start(). 2. Iterate through foreach loop through all key-value pairs in the $_SESSION array. 3. When processing complex data structures, use is_array() or is_object() functions and use print_r() to output detailed information. 4. When optimizing traversal, paging can be used to avoid processing large amounts of data at one time. This will help you manage and use PHP session data more efficiently in your actual project.

Explain how to use sessions for user authentication.Explain how to use sessions for user authentication.Apr 26, 2025 am 12:04 AM

The session realizes user authentication through the server-side state management mechanism. 1) Session creation and generation of unique IDs, 2) IDs are passed through cookies, 3) Server stores and accesses session data through IDs, 4) User authentication and status management are realized, improving application security and user experience.

Give an example of how to store a user's name in a PHP session.Give an example of how to store a user's name in a PHP session.Apr 26, 2025 am 12:03 AM

Tostoreauser'snameinaPHPsession,startthesessionwithsession_start(),thenassignthenameto$_SESSION['username'].1)Usesession_start()toinitializethesession.2)Assigntheuser'snameto$_SESSION['username'].Thisallowsyoutoaccessthenameacrossmultiplepages,enhanc

What are some common problems that can cause PHP sessions to fail?What are some common problems that can cause PHP sessions to fail?Apr 25, 2025 am 12:16 AM

Reasons for PHPSession failure include configuration errors, cookie issues, and session expiration. 1. Configuration error: Check and set the correct session.save_path. 2.Cookie problem: Make sure the cookie is set correctly. 3.Session expires: Adjust session.gc_maxlifetime value to extend session time.

How do you debug session-related issues in PHP?How do you debug session-related issues in PHP?Apr 25, 2025 am 12:12 AM

Methods to debug session problems in PHP include: 1. Check whether the session is started correctly; 2. Verify the delivery of the session ID; 3. Check the storage and reading of session data; 4. Check the server configuration. By outputting session ID and data, viewing session file content, etc., you can effectively diagnose and solve session-related problems.

What happens if session_start() is called multiple times?What happens if session_start() is called multiple times?Apr 25, 2025 am 12:06 AM

Multiple calls to session_start() will result in warning messages and possible data overwrites. 1) PHP will issue a warning, prompting that the session has been started. 2) It may cause unexpected overwriting of session data. 3) Use session_status() to check the session status to avoid repeated calls.

How do you configure the session lifetime in PHP?How do you configure the session lifetime in PHP?Apr 25, 2025 am 12:05 AM

Configuring the session lifecycle in PHP can be achieved by setting session.gc_maxlifetime and session.cookie_lifetime. 1) session.gc_maxlifetime controls the survival time of server-side session data, 2) session.cookie_lifetime controls the life cycle of client cookies. When set to 0, the cookie expires when the browser is closed.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.