Home Backend Development PHP Problem How to solve nginx php403 error

How to solve nginx php403 error

Nov 23, 2022 am 09:59 AM
php nginx

nginx php403 error solution: 1. Modify file permissions or enable selinux; 2. Modify php-fpm.conf and add the required file extension; 3. Modify the content of php.ini to "cgi.fix_pathinfo = 0"; 4. Restart php-fpm.

How to solve nginx php403 error

The operating environment of this tutorial: linux5.9.8 system, PHP version 8.1, Dell G3 computer.

How to solve nginx php403 error?

nginx php 403 Cause Analysis

Problem:

When accessing the configured website, an error message appears: Access Denied (403)

Common solutions:

1. File permission problem

It may be a file permission problem, there is no read permissions.

Or selinux is not closed.

2. security.limit_extensions

Check nginx error log error.log and find the following error:

1

2

2016/07/07 10:20:13 [error] 17710#0: *2145 FastCGI sent in stderr: "Access to the script '/home/www/game/10313156.html' has been denied (see security.limi

t_extensions)" while reading response header from......

Copy after login

Starting from 5.3.9, PHP has officially added a configuration "security.limit_extensions". By default, only files with the extension ".php" are allowed to be executed, causing the problem that other types of files are not supported.

Official description:

1

2

3

4

5

6

7

; Limits the extensions of the main script FPM will allow to parse. This can

; prevent configuration mistakes on the web server side. You should only limit

; FPM to .php extensions to prevent malicious users to use other extensions to

; exectute php code.

; Note: set an empty value to allow all extensions.

; Default Value: .php

;security.limit_extensions = .php .php3 .php4 .php5

Copy after login

Modify php-fpm.conf: (Add the required file extension)

1

security.limit_extensions = .php .html .js .css .jpg .jpeg .gif .png .htm

Copy after login

3. cgi.fix_pathinfo

When accessed through this url, an Acess denied error is displayed.

nginx error log:

1

2016/07/08 09:47:12 [error] 24297#0: *3348 FastCGI sent in stderr: "Access to the script '/home/www/home.php/game/qr' has been denied (see security.limit_extensions)" while reading response header......

Copy after login

Modify php.ini: (cgi.fix_pathinfo defaults to 1)

1

cgi.fix_pathinfo = 1

Copy after login

Official description:

1

2

3

4

5

6

7

; cgi.fix_pathinfo provides *real* PATH_INFO/PATH_TRANSLATED support for CGI.  PHP's

; previous behaviour was to set PATH_TRANSLATED to SCRIPT_FILENAME, and to not grok

; what PATH_INFO is.  For more information on PATH_INFO, see the cgi specs.  Setting

; this to 1 will cause PHP CGI to fix its paths to conform to the spec.  A setting

; of zero causes PHP to behave as before.  Default is 1.  You should fix your scripts

; to use SCRIPT_FILENAME rather than PATH_TRANSLATED.

; http://php.net/cgi.fix-pathinfo

Copy after login

In fact, cgi.fix_pathinfo = 1 will cause file type error parsing vulnerability. It is recommended to set cgi.fix_pathinfo = 0.

(About the understanding of the vulnerability:

When cgi.fix_pathinfo=1, access path:/foo.jpg/file.php, if the file.php file does not exist, the php parser It will try to guess which file you want to execute and look back along the path. If foo.jpg exists and contains PHP code, the PHP parser will execute foo.jpg.

When cgi.fix_pathinfo=0 At this time, the PHP interpreter only tries the given path and stops processing if the file is not found.

)

But setting cgi.fix_pathinfo = 0 may cause many MVC frameworks (such as ThinkPHP ) cannot function properly.

4.

Set on php.ini: open_basedir=/home:/tmp/:/proc/

Restart php-fpm

When accessing a web page and pressing ctrl F5 to refresh frequently, an Access Denied error will be reported. Access Denied only appears occasionally, not 403 all the time.

nginx error log record:

1

2

3

2016/07/09 08:32:40 [error] 26954#0: *2127721 FastCGI sent in stderr: "PHP message: PHP Warning:  Unknown: open_basedir restriction in effect. File(/home/www/touch/web/index.php) is not within the allowed path(s): (/home/wwwroot:/tmp/:/proc/) in Unknown on line 0

PHP message: PHP Warning:  Unknown: failed to open stream: Operation not permitted in Unknown on line 0

Unable to open primary script: /home/www/touch/web/index.php (Permission denied)" while reading response header from upstream, client: 117.136.1.22, server: test.hjq.com, request: "GET /index.php?c=Zs&a=getcontent HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "test.hjq.com"

Copy after login

1

2

3

2、In your nginx config file set fastcgi_pass to your socket address (e.g. unix:/var/run/php-fpm/php-fpm.sock;) instead of your server address and port.

3、Check your SCRIPT_FILENAME fastcgi param and set it according to the location of your files.

4、In your nginx config file include fastcgi_split_path_info ^(.+\.php)(/.+)$; in the location block where all the other fastcgi params are defined.

Copy after login

Recommended learning: "PHP Video Tutorial"

The above is the detailed content of How to solve nginx php403 error. 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

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

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)

PHP's Purpose: Building Dynamic Websites PHP's Purpose: Building Dynamic Websites Apr 15, 2025 am 12:18 AM

PHP is used to build dynamic websites, and its core functions include: 1. Generate dynamic content and generate web pages in real time by connecting with the database; 2. Process user interaction and form submissions, verify inputs and respond to operations; 3. Manage sessions and user authentication to provide a personalized experience; 4. Optimize performance and follow best practices to improve website efficiency and security.

PHP and Python: Code Examples and Comparison PHP and Python: Code Examples and Comparison Apr 15, 2025 am 12:07 AM

PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

PHP: Handling Databases and Server-Side Logic PHP: Handling Databases and Server-Side Logic Apr 15, 2025 am 12:15 AM

PHP uses MySQLi and PDO extensions to interact in database operations and server-side logic processing, and processes server-side logic through functions such as session management. 1) Use MySQLi or PDO to connect to the database and execute SQL queries. 2) Handle HTTP requests and user status through session management and other functions. 3) Use transactions to ensure the atomicity of database operations. 4) Prevent SQL injection, use exception handling and closing connections for debugging. 5) Optimize performance through indexing and cache, write highly readable code and perform error handling.

How to check whether nginx is started How to check whether nginx is started Apr 14, 2025 pm 01:03 PM

How to confirm whether Nginx is started: 1. Use the command line: systemctl status nginx (Linux/Unix), netstat -ano | findstr 80 (Windows); 2. Check whether port 80 is open; 3. Check the Nginx startup message in the system log; 4. Use third-party tools, such as Nagios, Zabbix, and Icinga.

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

How to check nginx version How to check nginx version Apr 14, 2025 am 11:57 AM

The methods that can query the Nginx version are: use the nginx -v command; view the version directive in the nginx.conf file; open the Nginx error page and view the page title.

How to configure cloud server domain name in nginx How to configure cloud server domain name in nginx Apr 14, 2025 pm 12:18 PM

How to configure an Nginx domain name on a cloud server: Create an A record pointing to the public IP address of the cloud server. Add virtual host blocks in the Nginx configuration file, specifying the listening port, domain name, and website root directory. Restart Nginx to apply the changes. Access the domain name test configuration. Other notes: Install the SSL certificate to enable HTTPS, ensure that the firewall allows port 80 traffic, and wait for DNS resolution to take effect.

How to check the name of the docker container How to check the name of the docker container Apr 15, 2025 pm 12:21 PM

You can query the Docker container name by following the steps: List all containers (docker ps). Filter the container list (using the grep command). Gets the container name (located in the "NAMES" column).

See all articles