Table of Contents
Generate and Store Anti-CSRF Tokens
Validate the Token on Form Submission
Don’t Forget AJAX Requests and APIs
Bonus Tips: SameSite Cookies and HTTP-Only Forms
Home Backend Development PHP Tutorial How do I prevent cross-site request forgery (CSRF) attacks in PHP?

How do I prevent cross-site request forgery (CSRF) attacks in PHP?

Jun 28, 2025 am 02:25 AM
php csrf

To prevent CSRF attacks in PHP, implement anti-CSRF tokens. 1) Generate and store secure tokens using random_bytes() or bin2hex(random_bytes(32)), save them in $_SESSION, and include them in forms as hidden inputs. 2) Validate tokens on submission by strictly comparing the POST token with the session-stored one; reject mismatched requests with a 403 error. 3) Protect AJAX/API requests by including the token in headers or body, often retrieved from a meta tag. 4) Use htmlspecialchars() when outputting tokens to prevent XSS leaks. 5) Regenerate tokens after critical actions like login. 6) Set SameSite=Strict/Lax for session cookies and avoid GET for state changes. 7) Re-authenticate users for sensitive actions. These steps ensure comprehensive CSRF protection across all request types while maintaining security integrity.

How do I prevent cross-site request forgery (CSRF) attacks in PHP?

To prevent CSRF attacks in PHP, you need to implement a solid anti-CSRF strategy—mainly by using tokens. The idea is simple: every state-changing request (like form submissions) should include a unique, unpredictable token that only the legitimate user knows. Without this token, the server shouldn’t process the request.

Here’s how to actually do it well in practice.


Generate and Store Anti-CSRF Tokens

Every time you display a form that performs an action (like submitting settings or making a purchase), generate a secure token and store it somewhere safe on the server side—like in the session.

  • Use random_bytes() or bin2hex(random_bytes(32)) to create a strong token.
  • Save it in $_SESSION so you can compare it later when the form is submitted.

For example:

if (empty($_SESSION['csrf_token'])) {
    $_SESSION['csrf_token'] = bin2hex(random_bytes(50));
}

Then in your form:

<input type="hidden" name="csrf_token" value="<?= htmlspecialchars($_SESSION['csrf_token']) ?>">

This way, each form submission includes a token that the attacker can't guess or reproduce.


Validate the Token on Form Submission

When the form is submitted, check if the token in the POST data matches what’s stored in the session.

  • Always check for the presence of the token.
  • Compare it strictly (===) to avoid type-juggling issues.
  • If it doesn’t match, reject the request with a 403 error or similar.

Example code:

if (!isset($_POST['csrf_token']) || $_POST['csrf_token'] !== $_SESSION['csrf_token']) {
    http_response_code(403);
    die('Invalid CSRF token.');
}

A small but important detail: always use htmlspecialchars() when outputting the token into HTML to prevent XSS from leaking the token.

Also, don’t forget to rotate or regenerate the token after critical actions like login or password change.


Don’t Forget AJAX Requests and APIs

If your site uses JavaScript to submit forms or make API calls, those requests also need CSRF protection.

  • Include the CSRF token in the headers or body of the AJAX request.
  • You can store the token in a meta tag or inline script and read it from there when making the call.

For example, set a meta tag in your HTML head:

<meta name="csrf-token" content="<?= htmlspecialchars($_SESSION['csrf_token']) ?>">

Then in your JS:

fetch('/update-profile', {
    method: 'POST',
    headers: {
        'X-CSRF-Token': document.querySelector('meta[name="csrf-token"]').content
    },
    body: new URLSearchParams({ name: 'John Doe' })
});

On the backend, look for the token in the X-CSRF-Token header and validate it just like with regular forms.

One thing to note: if you're building a single-page app (SPA) or mobile app that talks to your PHP backend, consider using same-site cookies and CSRF tokens together for better protection.


Bonus Tips: SameSite Cookies and HTTP-Only Forms

Even with tokens, there are extra steps you can take:

  • Set SameSite=Strict or Lax on your session cookie to reduce cross-origin requests.
  • Make sure your forms only accept POST requests where needed—don’t allow GET-based state changes.
  • For sensitive operations (like deleting an account), re-authentication helps add another layer.

These aren’t replacements for CSRF tokens, but they work well alongside them.


That’s basically it. CSRF protection in PHP boils down to generating good tokens, validating them properly, and making sure they’re included in all relevant requests. It’s not overly complex, but easy to mess up if you skip even one step.

The above is the detailed content of How do I prevent cross-site request forgery (CSRF) attacks in PHP?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
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

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

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.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Commenting Out Code in PHP Commenting Out Code in PHP Jul 18, 2025 am 04:57 AM

There are three common methods for PHP comment code: 1. Use // or # to block one line of code, and it is recommended to use //; 2. Use /.../ to wrap code blocks with multiple lines, which cannot be nested but can be crossed; 3. Combination skills comments such as using /if(){}/ to control logic blocks, or to improve efficiency with editor shortcut keys, you should pay attention to closing symbols and avoid nesting when using them.

Tips for Writing PHP Comments Tips for Writing PHP Comments Jul 18, 2025 am 04:51 AM

The key to writing PHP comments is to clarify the purpose and specifications. Comments should explain "why" rather than "what was done", avoiding redundancy or too simplicity. 1. Use a unified format, such as docblock (/*/) for class and method descriptions to improve readability and tool compatibility; 2. Emphasize the reasons behind the logic, such as why JS jumps need to be output manually; 3. Add an overview description before complex code, describe the process in steps, and help understand the overall idea; 4. Use TODO and FIXME rationally to mark to-do items and problems to facilitate subsequent tracking and collaboration. Good annotations can reduce communication costs and improve code maintenance efficiency.

Quick PHP Installation Tutorial Quick PHP Installation Tutorial Jul 18, 2025 am 04:52 AM

ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre

Learning PHP: A Beginner's Guide Learning PHP: A Beginner's Guide Jul 18, 2025 am 04:54 AM

TolearnPHPeffectively,startbysettingupalocalserverenvironmentusingtoolslikeXAMPPandacodeeditorlikeVSCode.1)InstallXAMPPforApache,MySQL,andPHP.2)Useacodeeditorforsyntaxsupport.3)TestyoursetupwithasimplePHPfile.Next,learnPHPbasicsincludingvariables,ech

Improving Readability with Comments Improving Readability with Comments Jul 18, 2025 am 04:46 AM

The key to writing good comments is to explain "why" rather than just "what was done" to improve the readability of the code. 1. Comments should explain logical reasons, such as considerations behind value selection or processing; 2. Use paragraph annotations for complex logic to summarize the overall idea of functions or algorithms; 3. Regularly maintain comments to ensure consistency with the code, avoid misleading, and delete outdated content if necessary; 4. Synchronously check comments when reviewing the code, and record public logic through documents to reduce the burden of code comments.

Writing Effective PHP Comments Writing Effective PHP Comments Jul 18, 2025 am 04:44 AM

Comments cannot be careless because they want to explain the reasons for the existence of the code rather than the functions, such as compatibility with old interfaces or third-party restrictions, otherwise people who read the code can only rely on guessing. The areas that must be commented include complex conditional judgments, special error handling logic, and temporary bypass restrictions. A more practical way to write comments is to select single-line comments or block comments based on the scene. Use document block comments to explain parameters and return values at the beginning of functions, classes, and files, and keep comments updated. For complex logic, you can add a line to the previous one to summarize the overall intention. At the same time, do not use comments to seal code, but use version control tools.

Mastering PHP Block Comments Mastering PHP Block Comments Jul 18, 2025 am 04:35 AM

PHPblockcommentsareusefulforwritingmulti-lineexplanations,temporarilydisablingcode,andgeneratingdocumentation.Theyshouldnotbenestedorleftunclosed.BlockcommentshelpindocumentingfunctionswithPHPDoc,whichtoolslikePhpStormuseforauto-completionanderrorche

PHP Development Environment Setup PHP Development Environment Setup Jul 18, 2025 am 04:55 AM

The first step is to select the integrated environment package XAMPP or MAMP to build a local server; the second step is to select the appropriate PHP version according to the project needs and configure multiple version switching; the third step is to select VSCode or PhpStorm as the editor and debug with Xdebug; in addition, you need to install Composer, PHP_CodeSniffer, PHPUnit and other tools to assist in development.

See all articles