search
HomeBackend DevelopmentPHP TutorialIn PHP, what is the difference between cookies and sessions, and what are the benefits of using them? (Please give me the answer, not Baidu, thank you)?

Reply content:

Let’s not talk about sessions and cookies in Php. Let’s take a look at what session and cookies are in a normal web.

Cookie is actually a technology on the browser side. Since HTTP itself is stateless, generally speaking, the server does not know who is requesting each time. Therefore, a web session allows temporary storage of some content on the client through set-cookie in the HTTP header. The client needs Each HTTP request in this session is accompanied by the contents of the current cookie (it will not be sent if cookies are disabled). Sessions here are generally defined by domain names.

But cookies have two big flaws: 1. Cookies are stored on the client side, so cookies can be read, misappropriated and modified. This means that if any critical information, such as login information, is stored using cookies, others can read, delete, and modify it at will. 2. Other disguised sites may be able to directly obtain your cookie content.

So how to access this information so that it is difficult for the client to delete cookies at will and disguise other users? Generally speaking, there are two major categories of methods: 1. Encrypt the cookie; 2. Only store a signature with self-verification in the cookie, and then store the key data on the server side. This is the session.

session is the application of cookies. Encrypting sessions stored on the client is the easiest to implement and does not bring additional storage burden to the server. Sessions of many new micro-frameworks are implemented in this way (and are not stored on the server). The second is to store it on the server. Optional storage locations include but are not limited to memory, files, external databases, etc.

Php comes with its own library. Cookie is to add cookies that need to be stored on the client side to the response. Session is to add a session_id to the cookie, and then store the things that need to be stored on the server side in the form of files by default.

By the way, modern browsers generally support localStorage. Firstly, it is accessed through the front end but not available from the backend. It is slightly safer for users. Secondly, the amount of storage can be much larger. Thirdly, there is a certain degree of prevention. The capabilities of low-end crawlers. If you do not need to consider compatibility with old browsers, it is more recommended to use localStorage + front-end and back-end separation, and return localStorage content (session_id or encrypted storage content) through js in the form of ajax to replace cookies. Cookie is to store data on the client side. Session is to store data on the server side. The client only stores one ID. The first floor said it very well.
In fact, the biggest difference is that the cookie exists on the client side and the session exists on the server side. And generally speaking, the session does depend on the session id in the cookie. In fact, you can also set the session id yourself, and then specify the session id when using the session. The function of session id is to specify the file stored in the session, so you can use this trick after cookies are disabled.
Another point to add is that sessions should be used with caution in a distributed architecture, because session data may be lost. Of course, you can also rewrite the session so that the session is stored in the cache or database. You can understand it this way, the cookie is someone else's box, and the session is your own box. What are the benefits of the box? Save something
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
Working with Flash Session Data in LaravelWorking with Flash Session Data in LaravelMar 12, 2025 pm 05:08 PM

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

cURL in PHP: How to Use the PHP cURL Extension in REST APIscURL in PHP: How to Use the PHP cURL Extension in REST APIsMar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Simplified HTTP Response Mocking in Laravel TestsSimplified HTTP Response Mocking in Laravel TestsMar 12, 2025 pm 05:09 PM

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 Best PHP Chat Scripts on CodeCanyon12 Best PHP Chat Scripts on CodeCanyonMar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Explain the concept of late static binding in PHP.Explain the concept of late static binding in PHP.Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

PHP Logging: Best Practices for PHP Log AnalysisPHP Logging: Best Practices for PHP Log AnalysisMar 10, 2025 pm 02:32 PM

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

Discover File Downloads in Laravel with Storage::downloadDiscover File Downloads in Laravel with Storage::downloadMar 06, 2025 am 02:22 AM

The Storage::download method of the Laravel framework provides a concise API for safely handling file downloads while managing abstractions of file storage. Here is an example of using Storage::download() in the example controller:

HTTP Method Verification in LaravelHTTP Method Verification in LaravelMar 05, 2025 pm 04:14 PM

Laravel simplifies HTTP verb handling in incoming requests, streamlining diverse operation management within your applications. The method() and isMethod() methods efficiently identify and validate request types. This feature is crucial for building

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 Article

Hot Tools

EditPlus Chinese cracked version

EditPlus Chinese cracked version

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

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools