Home  >  Article  >  Backend Development  >  The use and analysis of Session in PHP_PHP Tutorial

The use and analysis of Session in PHP_PHP Tutorial

WBOY
WBOYOriginal
2016-07-15 13:25:34775browse

The Chinese translation of Session is called "conversation". Its original meaning refers to a series of actions/messages that have a beginning and an end. For example, when making a phone call, the series of processes from picking up the phone to dialing to hanging up the phone can be called It is a Session. The current understanding of Session in the society is very confusing: sometimes we can see the words "During a browser session,...", the session here refers to the period from the opening to closing of a browser window; you can also see When referring to the sentence "the user (client) during a session", it may refer to a series of actions of the user (usually a series of actions related to a specific purpose, such as from logging in to purchasing goods to checking out. Such an online shopping process; however, sometimes it may only refer to a connection; the difference can only be inferred from the context.

However, when the word Session is associated with the network protocol, it also It often implies two meanings: "connection-oriented" and/or "maintaining state". "Connection-oriented" means that the communicating parties must establish a communication channel before communicating, such as making a phone call, until the other party answers the phone. Communication can begin. "Keeping status" means that the communicating party can associate a series of messages so that the messages can depend on each other. For example, a waiter can recognize an old customer who comes again and remember that the customer owed money last time. One dollar in the store. Examples of this category are "a TCP Session" or "a POP3 Session".

Given that this confusion is irreversible, it is difficult to have a unified standard for defining Session. . When reading information about Session, we can only infer and understand it from the context. But we can understand it this way: For example, when we make a call, the call remains connected from the moment we make the call to the time we hang up. state, so this connected state is called Session. It is a public variable that always exists during the interaction between the visitor and the entire website. When the client does not support COOKIE, in order to ensure that the data is correct and safe, the Session variable is used. Visitors to the website are assigned a unique identifier, the so-called session ID. It is either stored in a cookie on the client or passed through the URL. The invention of Session fills the limitations of the HTTP protocol: HTTP protocol. It is considered a stateless protocol and cannot know the user's browsing status. After it completes the response on the server side, the server loses contact with the browser. This is consistent with the original purpose of the HTTP protocol. The client only needs to. Simply request the server to download certain files. Neither the client nor the server needs to record each other's past actions. Each request is independent, just like a customer and a vending machine or an ordinary (non-member) The relationship between hypermarkets is the same.

Therefore, the relevant information of the user is recorded through Session (cookie is another solution) for confirmation when the user makes a request to the web server again as this identity. The invention of sessions allows a user to preserve his or her information when switching between multiple pages. Website programmers all have this experience. The variables in each page cannot be used in the next page (although form and url can also be implemented, but these are very unsatisfactory methods), while the variables registered in the Session are Can be used as a global variable.

So what is the use of Session? Everyone has used the shopping cart when shopping online. You can add the products you choose to the shopping cart at any time, and finally go to the checkout counter to check out. During the entire process, the shopping cart has been playing the role of temporarily storing the selected products. It is used to track the user's activities on the website. This is the role of Session. It can be used for user identity authentication, program status recording, and between pages. Parameter passing, etc.

COOKIE technology is used in the implementation of Session. Session will save a COOKIE containing Session_id (Session number) on the client side; save other Session variables on the server side, such as Session_name, etc. When the user requests the server, the Session_id is also sent to the server. By extracting the variables saved on the server side through the Session_id, you can identify who the user is. At the same time, it is not difficult to understand why Session sometimes fails.

When the client disables COOKIE (click "Tools" - "Internet Options" in IE, click "Security" - "Custom Level" item in the pop-up dialog box, change "Allow each conversation" COOKIE" is set to disabled), the Session_id will not be passed, and the Session will be invalid at this time. However, php5 can automatically check the cookie status on the Linux/Unix platform. If the client is disabled, the system will automatically append the Session_id to the URL and pass it. Windows hosts do not have this function.

Session common functions and usage

Session_start(): Start a session or return an existing session.

Note: This function has no parameters and the return value is true. If you use cookie-based Sessions, the browser must not produce any output before using Session_start(), otherwise the following error will occur:

Warning: Cannot send Session cache limiter - headers already sent (output started at /usr/local/apache/htdocs/cga/member/1.php:2)……

You can enable Session.auto_start=1 in php.ini, so that you don’t need to call Session_start() every time before using Session. But there are some limitations to enabling this option, if Session.auto_start is indeed enabled, you cannot put the object into the session because the class definition must be loaded before starting the session to recreate the object in the session.

All registered variables will be serialized after the request is completed. Variables that are registered but not defined are marked as undefined. These variables are also not defined by the session module on subsequent accesses unless the user later defines them.

Some types of data cannot be serialized and therefore cannot be saved in the session. Including resource variables or objects with circular references (that is, one object passes a reference to itself to another object).


www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/446675.htmlTechArticleThe Chinese translation of Session is called "conversation", and its original meaning refers to a series of actions/messages that have a beginning and an end, such as A series of events from picking up the phone to dialing to hanging up when making a phone call...
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