Home  >  Article  >  Backend Development  >  PHP session processing analysis

PHP session processing analysis

王林
王林forward
2020-01-06 17:57:023049browse

PHP session processing analysis

Session handling is an important concept in PHP that allows user information to remain unchanged across all pages of a website or application.

What is session in PHP?

Session is a mechanism that retains information on different web pages to identify users as they browse a website or application.

Everyone must have this question: Why does the website need sessions? Before discussing this issue, we need to go back and look at how the HTTP protocol works.

The HTTP protocol is a stateless protocol, which means that the server cannot remember a specific user between requests. For example, when you visit a web page, the server is only responsible for serving the content of the requested page. So when you visit other pages on the same website, the web server interprets each request individually as if they have nothing to do with each other. The server has no way of knowing that every request comes from the same user.

(Free learning video tutorial: php video tutorial)

The following figure briefly describes the HTTP protocol.

PHP session processing analysis

In this process, if you want to display information for a specific user, you must authenticate the user in each request. Imagine if every time you make a request, you need to enter your username and password on the page for authentication; this is too cumbersome and not practical at all. However, session comes in handy at this time.

Session allows users to share information across different pages of a single site or application, so it helps maintain state. This lets the server know that all requests are coming from the same user, allowing the site to display user-specific information and preferences.

The following diagram describes how the HTTP protocol is used with sessions.

PHP session processing analysis

#How does PHP handle sessions?

1. Start the session

Whenever you want to process session variables, you need to ensure that the session has been started. There are several ways to start a session in PHP.

1), use the session_start function

This is the most common method, in which the session is started by the session_start function.

PHP session processing analysis

It is important that the session_start function is called at the beginning of the script before any output is sent to the browser. Otherwise, you will encounter the infamous Headers are already sent error.

2), Automatically start the session

If you need to use the session throughout the application, you can also choose to automatically start the session without using the session_start function.

There is a configuration option session.auto_start in the php.ini file that allows us to automatically start a session for each request. By default, it is set to 0, we can set it to 1 to enable the auto-start feature.

PHP session processing analysis

#2. Get the session ID

The server creates a unique id for each new session. If you want to get the session ID, you can use the session_id function as shown in the following snippet.

PHP session processing analysis

This should give you the current session ID. The session_id function is interesting because it can also take one parameter - a session ID. If you want to replace the system-generated session ID with your own, you can provide it to the first parameter of the session_id function.

PHP session processing analysis

It is important to note that when you want to start a session with a custom session ID, the session_id function must be called before session_start.

3. Create session variables

Once the session is started, $_SESSION will initialize the super global array with the corresponding session information. By default it is initialized with a blank array, you can use key-value pairs to store more information.

Let’s take a look at how to initialize session variables through code examples.

PHP session processing analysis

As shown above, we use the session_start function to start a session at the beginning of the script; after that, we initialize several session variables; finally, we use the $_SESSION super global access these variables.

When using the $_SESSION superglobal to store data in a session, it is ultimately stored in the corresponding session file on the server that is created when the session is started. This way session data is shared across multiple requests.

As we discussed, session information is shared between requests, so session variables initialized on one page will also be accessible from other pages until the session expires. Normally, the session expires when the browser is closed.

4. Modify and delete session variables

We can modify or delete session variables previously created in the application just like modifying regular PHP variables.

Let’s take an example to see how to modify session variables.

PHP session processing analysis

In the above script, we first check whether the $_session['count'] variable is set. If it is not set, we will set it to 1, otherwise we will increment it by 1. So if you refresh this page multiple times, you can see the counter incrementing by one each time!

On the other hand, if you want to delete the session variable, you can use the unset function, as shown in the following code snippet:

PHP session processing analysis

In this way, we cannot Access the $_SESSION['logged_in_user_id'] variable again. Because it has been deleted by the unset function.

5. Destroy the session

We know above that we can use the unset function to delete specific session variables; so what should we do if we want to delete all session-related data at once?

It’s actually very simple, we can use the session_destroy function.

Let’s take a look at how the session_destroy function works.

PHP session processing analysis

Description: The session_destroy function deletes all content stored in the current session. Therefore, when the session data stored on disk is deleted by the session_destroy function, we will see an empty session variable from subsequent requests.

Note: Usually, the session_destroy function is used only when the user logs out

Recommended related article tutorials: php tutorial

The above is the detailed content of PHP session processing analysis. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:cnblogs.com. If there is any infringement, please contact admin@php.cn delete