search
HomeBackend DevelopmentPHP TutorialDetailed introduction to cookies and sessions (pictures and text)

This article brings you a detailed introduction (pictures and texts) about cookies and sessions. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.

Cookie technology

Cookie is a browser-side technology that can save data on the browser! Cookie refers to the data saved on the browser!

PHP supports cookie technology! PHP can issue instructions to the browser to save data to the browser!

The browser is responsible for saving data, and php is responsible for controlling what data the browser saves! (php uses cookie technology on the browser)

The cookie data saved on the browser can carry the data and make a request to the server every time the browser requests the server. At this time The script on the server can get this data!

Basic use

Set cookie variables, add, change, delete

Use internal functions setcookie Complete

Form: setcookie(name, value)

Get cookie variable, read

Use predefined array variable:$_COOKIE

This variable stores all cookie data carried when requesting from the browser!

Each element is a cookie variable data! The subscript is the name, the value is the value!

Basic principles

Using firebug’s network tab:

What did you do when setting up?

In response, the server sends an instruction to add a cookie variable to the browser!

After receiving the instruction, the browser added a cookie data to the browser!

When obtained, it did What?

The browser will carry all cookies of the current site to the server upon request!

php will automatically obtain the cookie carried by the browser and form a $_COOKIE array, which can be used by user scripts!

Advanced use

1. Cookie data can only be string data!

2.setcookie function can add, modify and delete!

If it does not exist, add it; if it exists, modify it!

Delete, you can use the form of leaving the value blank!

3. The expiration period of cookie variables

There is a concept of validity period for cookie data:

Default, temporary cookies. It will be saved until the browser is closed!

At the same time, it is supported to add the third parameter of setcookie to modify the validity period of cookie variables. The validity period is expressed as a timestamp, indicating at which point in time it will expire!

php can obtain the current timestamp through the time() function, and extend the cookie time by increasing time() in increments!

At this time, the server will issue the following instructions to the browser:

Time is represented on the network using Greenwich Mean Time! That time without the concept of time zones! GMT

The browser knows the validity period of the cookie variable!

Commonly used operations:

1 .Cookie has the concept of a valid path

The cookie variable will only take effect in the current directory and its descendant directories!

Set under test/, you can access under test/sub/

Inversely:

That’s because of the cookie:

You can change the effective path of cookie data:

Do it through the fourth parameter of setcookie Modification:

/ indicates that the site root directory is valid! Valid for the entire site!

5. The concept of cookie sub-domain name

Cookies strictly distinguish domain names.

Supports sharing between subdomain names:

Use the fifth parameter to set

Validity period, valid path, valid Subdomain!

6, $_COOKIE cannot capture the cookie variable set by the current script!

#$_COOKIE is all the cookies carried by the browser when requesting!

The current setting will only be used when requesting next time!

session technology, session technology

Scenario:

Cookie problem

Because the data itself is on the browser side:

Data security issues!

Data must always be carried when requesting!

How to solve it? Pay attention to sharing data between multiple requests of the browser!

Put the data on the server side, and at the same time distinguish the data from the browser, and share the data between multiple requests of the browser!

On the server, add a data space for each browser that visits, and then assign different unique identifiers to these data spaces! Assign a unique identifier to each browser. The identifier of the server-side database space should correspond one-to-one to the

requirement. The browser carries the identifier every time it makes a request. At this time, the server can obtain the identifier and use the identifier. The data space is determined, but all requested data processing is completed within the current determined space!

The unique identifier assigned by the server to the browser is stored in the browser's cookie, which ensures that the browser carries it every time it comes!

The server determines the identification for each new browser access (browser without identification), and generates a unique data space on the server!

Basic use

Directly operate the $_SESSION array to complete the storage and retrieval of session data!

Each session data corresponds to an element in $_SESSION! Operating on elements means operating on session data!

However, session technology, including generating session identifiers, opening up session data space, allocating session identifiers to browsers, etc., all require the support of PHP's session mechanism!

Therefore, you need to enable session support first before you can operate the $_SESSION variable to operate session data!

Open:

session_start();

Operation:

$_SESSION;

Open first and then operate:

Update and delete:

Basic Principle

SessionID saved in browser-side cookie:

When the current browser makes a request to the server for the first time, the server cannot determine the identity of the browser

A unique identifier will be regenerated and saved to the browser in the form of a cookie!

The default cookie variable name is: PHPSESSID.

This cookie scalar is also called sessionID!

When the browser has the sessionid cookie variable, subsequent requests will carry the ID and make requests:

The server side is the session data space

By default, PHP will generate a file in the space where the session data is saved! Distinguish which ID it belongs to by the name of the file!

The default is saved in the temporary directory of the server operating system:

Approximate process:

Test:

Use session to complete login ID verification:

The above is the detailed content of Detailed introduction to cookies and sessions (pictures and text). For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:CSDN. If there is any infringement, please contact admin@php.cn delete
修复:谷歌浏览器请求太多错误 429 [已解决]修复:谷歌浏览器请求太多错误 429 [已解决]Apr 16, 2023 am 09:22 AM

近期很多Windows用户反映,当他们尝试访问某个URL时,PC上的GoogleChrome浏览器显示错误429。这是因为每次用户尝试在短时间内通过浏览器。通常,此错误是由网站生成的,以避免通过向服务器发送过多请求而被机器人或黑客入侵病毒。用户对在这个阶段可以做什么感到困惑,并因此感到失望。导致此错误的因素可能很多,我们在下面列出了其中一些因素。缓存内存和其他站点数据未清除从第三方来源安装的扩展系统上的一些有害软件病毒攻击在研究了上面列出的因素之后,我们在这篇文章中收集了一些修复程序,这

如果 Grammarly 无法在 Windows 10 浏览器上运行的 8 个重大修复如果 Grammarly 无法在 Windows 10 浏览器上运行的 8 个重大修复May 05, 2023 pm 02:16 PM

如果您在Windows10或11PC上遇到语法问题,本文将帮助您解决此问题。Grammarly是最流行的打字助手之一,用于修复语法、拼写、清晰度等。它已经成为写作专业人士必不可少的一部分。但是,如果它不能正常工作,它可能是一个非常令人沮丧的体验。许多Windows用户报告说此工具在他们的计算机上运行不佳。我们做了深入的分析,找到了这个问题的原因和解决方案。为什么Grammarly无法在我的PC上运行?由于几个常见原因,PC上的Grammarly可能无法正常工作。它包括以下内

如何修复 Google Chrome 上的 Roblox 403 禁止错误如何修复 Google Chrome 上的 Roblox 403 禁止错误May 19, 2023 pm 01:49 PM

许多Windows用户最近在尝试访问GoogleChrome浏览器中的网站URL时遇到了一个不寻常的错误,称为Roblox403禁止错误。即使在多次重新启动Chrome应用程序后,他们也无能为力。此错误可能有几个潜在原因,我们在下面概述并列出了其中一些。Chrome的浏览历史和其他缓存以及损坏的数据不稳定的互联网连接网站网址不正确从第三方来源安装的扩展在考虑了上述所有方面之后,我们提出了一些修复程序,可以帮助用户解决此问题。如果您遇到同样的问题,请查看本文中的解决方案。修复1

vue3中cookie如何使用vue3中cookie如何使用May 12, 2023 pm 02:19 PM

前言cookie使用最多的地方想必是保存用户的账号与密码,可以避免用户每次登录时都要重新输入1.vue中cookie的安装在终端中输入命令npminstallvue-cookies--save,即可安装cookies,安装之后在main.js文件中写下以下代码import{createApp}from'vue'importVueCookiesfrom'vue-cookies'constapp=createApp(App)app.co

PHP8.0中的Cookie库PHP8.0中的Cookie库May 14, 2023 pm 04:51 PM

在互联网应用开发中,使用Cookie是常见的一种方式来维护用户会话状态。在PHP语言中,处理Cookie的相关功能在语言的核心库中得到了完善的支持,在最新的PHP8.0版本中,Cookie库得到了进一步的增强。一、PHP中的CookieCookie是一个小文本文件,可以存储在用户的浏览器中,它通常被用来记录用户的个性化设置、登录状态等信息。Cookie是基

如何在 Google Chrome 中启用或禁用第三方 Cookie如何在 Google Chrome 中启用或禁用第三方 CookieApr 15, 2023 pm 02:07 PM

每个网站都通过创建cookie使用户更容易浏览他们的网页和浏览他们的网站。然而,网站创建了一些第三方cookie,使他们能够跟踪访问其他网站的用户,以便更好地了解他们,从而有助于展示广告和其他帖子。一些用户可能认为他们的数据遭到破坏或存在安全风险,而另一些用户可能认为允许这些第三方cookie跟踪他们以在浏览器上获取更多内容是很好的。所以我们在这篇文章中解释了如何在谷歌浏览器中启用或禁用第三方cookies,详细步骤如下。如何在GoogleChrome中启用第三方Cookie如果您认为要

php curl怎么设置cookiephp curl怎么设置cookieSep 26, 2021 am 09:27 AM

php curl设置cookie的方法:1、创建PHP示例文件;2、通过“curl_setopt”函数设置cURL传输选项;3、在CURL中传递cookie即可。

如何在ThinkPHP6中使用Cookie技术实现记住我功能如何在ThinkPHP6中使用Cookie技术实现记住我功能Jun 20, 2023 pm 03:33 PM

随着互联网技术的不断发展,越来越多的网站需要用户登录才能使用其功能。但是每次用户访问时都需要输入账号密码显然很不方便,因此“记住我”的功能应运而生。本文将介绍如何在ThinkPHP6中采用Cookie技术实现记住我功能。一、Cookie简介Cookie是一种服务器向客户端发送的小文件,在用户访问网站时存储在用户的计算机上。这些文件包含与用户相关的信息,如登录

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

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

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

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.