Error "No input file specified." Troubleshooting
Background
I will develop a Laravel project with my friends this afternoon , this project has been developed by my partner, so I cloned a copy to my computer, but after I configured it, when I opened the URL, it prompted "No input file specified." 404 error
Troubleshooting
-
First of all, I suspected that it was a problem with the project source code, and then I directly added the following sentence at the front of the entry file; I still got the same error when I accessed the website.
<?php exit(1);
Explain that it is not a problem with the source code of my project, and rule out code problems;
-
I began to suspect that it was a problem with my own environment, so I The tossing began. I deleted the project and started a new one, but it still didn't work. I found that this is the only problem with this project. So I'm sure it's not an environmental problem.
It means that it is not an environment problem, and it excludes environmental problems
-
I searched on Baidu, and some people said it might be a problem with Homestead.yaml, but I checked it carefully and found nothing wrong. So I Googled it and couldn't find a good reason.
Troubleshooting virtual machine configuration problems
-
So I thought it was not an environment problem, not a program problem~~~; finally I thought I should check inside the virtual machine. Finally, I saw this error in the ngnix log.
2019/05/23 12:31:44 [error] 5085#5085: *1 FastCGI sent in stderr: "PHP message: PHP Warning: Unknown: open_basedir restriction in effect. File(/home/vagrant/Code/haopai-git/public/index.php) is not within the allowed path(s): (/www/wwwroot/dev.guooo.top/:/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/vagrant/Code/haopai-git/public/index.php (Operation not permitted)" while reading response header from upstream, client: 192.168.10.1, server: hp.hopa.cc, request: "GET / HTTP/1.1", upstream: "fastcgi://unix:/var/run/php/php7.2-fpm.sock:", host: "hp.hopa.cc"
-
When I saw the above error, I also went online to look for it. The Internet mainly talked about the problem of configuring fastcgi_param in ngnix, but I didn’t think it was right, because other projects had no problems. There is a problem with this project alone. For some reason, I noticed "/www/wwwroot/". This folder should not exist in my computer, so I went to the project to search for this string, and finally found it in the .user.ini file. When I saw this file, I realized it was his problem, so I deleted the configuration in this file. The content of the file is as follows:
open_basedir=***********
-
Okay, the problem is solved.
Reflection
Looking back and thinking about it, in fact, I should have thought of looking at ngnix logs from the beginning. I have come into contact with the .user.ini file before. At that time, I only remembered that it was used to prevent cross-site attacks.
.user.ini Knowledge Points
Since PHP 5.3.0, PHP supports .htaccess style INI files on a per-directory basis. Such files are only processed by the CGI/FastCGI SAPI. This feature makes PECL's htscanner extension obsolete. If using Apache, using an .htaccess file has the same effect.
In addition to the main php.ini, PHP will also scan INI files in each directory, starting from the directory where the executed PHP file is located and going up to the web root directory ($_SERVER['DOCUMENT_ROOT'] Specified). If the PHP file being executed is outside the web root directory, only that directory will be scanned.
Only INI settings with PHP_INI_PERDIR and PHP_INI_USER modes are recognized in .user.ini style INI files.
For more Laravel related technical articles, please visit the Laravel Tutorial column to learn!
The above is the detailed content of Painful troubleshooting 'No input file specified.'. For more information, please follow other related articles on the PHP Chinese website!

This article guides building robust Laravel RESTful APIs. It covers project setup, resource management, database interactions, serialization, authentication, authorization, testing, and crucial security best practices. Addressing scalability chall

This article details implementing OAuth 2.0 authentication and authorization in Laravel. It covers using packages like league/oauth2-server or provider-specific solutions, emphasizing database setup, client registration, authorization server configu

The article discusses creating and customizing reusable UI elements in Laravel using components, offering best practices for organization and suggesting enhancing packages.

The article discusses creating and using custom validation rules in Laravel, offering steps to define and implement them. It highlights benefits like reusability and specificity, and provides methods to extend Laravel's validation system.

The article discusses best practices for deploying Laravel in cloud-native environments, focusing on scalability, reliability, and security. Key issues include containerization, microservices, stateless design, and optimization strategies.

When it comes to choosing a PHP framework, Laravel and Symfony are among the most popular and widely used options. Each framework brings its own philosophy, features, and strengths to the table, making them suited for different projects and use cases. Understanding their differences and similarities is critical to selecting the right framework for your development needs.

The article discusses creating and using custom Blade directives in Laravel to enhance templating. It covers defining directives, using them in templates, and managing them in large projects, highlighting benefits like improved code reusability and r

Laravel's Artisan console automates tasks like generating code, running migrations, and scheduling. Key commands include make:controller, migrate, and db:seed. Custom commands can be created for specific needs, enhancing workflow efficiency.Character


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

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

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

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

WebStorm Mac version
Useful JavaScript development tools

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
