Use cookies to track and identify users_PHP tutorial
Let's take a look at what's saved in the browser. If you are using IE5, there is a cookie directory in the windows directory. There are many text files in it. The file names are similar to wudong@15seconds[1].txt. These are the cookies used by the browser to save values. . In previous versions of IE, the contents of cookies were viewable, but now the contents have been encoded. Before the browser gets a Web page, it will first check whether the domain name of the page exists in the cookie. If there is a match, the browser will first send the matching cookie to the server, and then accept and process the cookie sent by the server. page.
Let’s take an example of cookie application: when I connect to Amazon.com, the browser will send the contents of the cookies it previously set to Amazon before accepting the first page. Then Amazon.com checks the transmitted content to see if there is relevant information in the database. After matching, it creates a customized page for me and transmits it.
Assigning a value to cookies
Cookies must be assigned a value before the server sends any content to the client's browser. To do this, the cookie settings must be placed within the
setcookie("CookieID",$USERID);
?>
< ;HTML>
The setcookie function has a total of six parameters, separated by commas:
Name is a string, for example: "CookieID". Colons, commas and spaces are not allowed in between. This parameter is required, while all other parameters are optional. If only this parameter is given, the cookie will be deleted.
The value of the cookie is usually a string variable, such as $USERID. You can also assign a ?? to it to skip setting the value.
The time when the cookie expires. If omitted (or assigned a value of zero), the cookie will expire at the end of the session. This parameter can be an absolute time, represented by DD-Mon-YYHH:MM:SS, for example: "24-Nov-9908:26:00". What is more commonly used is to set a relative time. This is achieved through the time() function or the mktime function. For example, time()+3600 will cause the cookie to expire after one hour.
A path used to match cookies. When there are multiple cookie settings with the same name on a server, this parameter is used to avoid confusion. Using the "/" path has the same effect as omitting this parameter. It should be noted that Netscape's cookie definition puts the domain name in front of the path, while PHP does the opposite.
The domain name of the server is also used to match cookies. It should be noted that a dot (.) must be placed before the domain name of the server. For example: ".friendshipcenter.com". Because unless there are more than two points, this parameter cannot be accepted.
The security level of the cookie is an integer. 1 means that this cookie can only be sent over "secure" networks. 0 or omitted means any type of network is acceptable.
Cookies and Variables
When the PHP script extracts a cookie from the client's browser, it will automatically convert it into a variable. For example: a cookie named CookieID will become the variable $CookieID.
The content of Cookies is reported in the HTTP_COOKIE_VARS array. You can also access the specified cookie value through this array and the name of the cookie:
print$HTTP_COOKIE_VARS[CookieID];
Remember each user
Let’s look back at the submitform.php3 file above. Its function is to put the customer’s name Added to the database, now I want to add something to it. I want to assign a unique user ID to each user, and then put this ID in Cookies, so that every time a user visits my website, I can know who he is through the cookie and the user ID in it. .
MySQL can be set to automatically assign a number to each new record. This number starts from 1 and automatically increases by 1 each time thereafter. With one line of SQL statements, you can easily add such a field to the data table. I call it USERID:
ALTERTABLEdbname
ADDCOLUMN
USERIDINT(11) NOTNULL
PRIMARYKEYAUTO_INCREMENT;
We have made some special settings for this field. First, define its type as an 11-bit integer through "INT(11)"; then use the "NOTNULL" keyword to prevent the value of this field from being NULL; then use "PRIMARYKEY" to set it as an index field, so that it can be searched will be faster; finally, "AUTO_INCREMENT" defines it as an automatically incremented field.
Once the user’s name has been inserted into the database, it’s time to set a cookie on their browser.What is used at this time is the value of the USERID field we just talked about:
mysql_connect(localhost,username,password);
mysql_select_db(dbname);
mysql_query( "INSERTINTOtablename(first_name,last_name)
VALUES('$first_name','$last_name')
");
setcookie("CookieID",
mysql_insert_id(),
time() +94608000,
"/");/*The cookie will expire after three years*/
?>
The PHP function mysql_insert_id() returns the value returned by The value of the field defined by AUTO_INCREMENT. In this way, as long as you don’t clear your browser’s cookies, the website will “remember” you forever
Read cookies
Let’s write a script like what Amazon.com does . First, the PHP script will check whether the client's browser has sent a cookie. If so, the user's name will be displayed. If the cookie is not found, a form is displayed asking the customer to register their name, then added to the database and the cookie is set while the customer is browsing.
First, let’s display the content of the cookie:
print$CookieID; > mysql_connect(localhost,username,password);
mysql_select_db(dbname);
$selectresult=mysql_query("SELECT*FROMtablename
WHEREUSERID='$CookieID'
" );
$row=mysql_fetch_array($selectresult);
echo "Welcome",$row[first_name],"!";
?>
That's it. I have no judgment in it and leave it to you to complete it
http://www.bkjia.com/PHPjc/315307.html

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

PHP is not dying, but constantly adapting and evolving. 1) PHP has undergone multiple version iterations since 1994 to adapt to new technology trends. 2) It is currently widely used in e-commerce, content management systems and other fields. 3) PHP8 introduces JIT compiler and other functions to improve performance and modernization. 4) Use OPcache and follow PSR-12 standards to optimize performance and code quality.

The future of PHP will be achieved by adapting to new technology trends and introducing innovative features: 1) Adapting to cloud computing, containerization and microservice architectures, supporting Docker and Kubernetes; 2) introducing JIT compilers and enumeration types to improve performance and data processing efficiency; 3) Continuously optimize performance and promote best practices.

In PHP, trait is suitable for situations where method reuse is required but not suitable for inheritance. 1) Trait allows multiplexing methods in classes to avoid multiple inheritance complexity. 2) When using trait, you need to pay attention to method conflicts, which can be resolved through the alternative and as keywords. 3) Overuse of trait should be avoided and its single responsibility should be maintained to optimize performance and improve code maintainability.

Dependency Injection Container (DIC) is a tool that manages and provides object dependencies for use in PHP projects. The main benefits of DIC include: 1. Decoupling, making components independent, and the code is easy to maintain and test; 2. Flexibility, easy to replace or modify dependencies; 3. Testability, convenient for injecting mock objects for unit testing.

SplFixedArray is a fixed-size array in PHP, suitable for scenarios where high performance and low memory usage are required. 1) It needs to specify the size when creating to avoid the overhead caused by dynamic adjustment. 2) Based on C language array, directly operates memory and fast access speed. 3) Suitable for large-scale data processing and memory-sensitive environments, but it needs to be used with caution because its size is fixed.

PHP handles file uploads through the $\_FILES variable. The methods to ensure security include: 1. Check upload errors, 2. Verify file type and size, 3. Prevent file overwriting, 4. Move files to a permanent storage location.

In JavaScript, you can use NullCoalescingOperator(??) and NullCoalescingAssignmentOperator(??=). 1.??Returns the first non-null or non-undefined operand. 2.??= Assign the variable to the value of the right operand, but only if the variable is null or undefined. These operators simplify code logic, improve readability and performance.


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

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

Zend Studio 13.0.1
Powerful PHP integrated development environment

SublimeText3 Chinese version
Chinese version, very easy to use

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

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),