PHP Analysis on Shell Script Permission Issues
1. Introduction to sudo
sudo allows root to assign some rights that ordinary users do not have, so that ordinary users can also have relevant permissions of the root user (for example, sudo can be assigned to a certain user certain command execution permission).
One of the important files for sudo is /etc/sudoers. Which users have what kind of commands can be executed depends on this file. Mainly, only users assigned in it can use sudo.
sudo -l 列出该用户能执行的命令 sudo -u user 以指定用户来执行命令 sudo -k 清楚入场券上的时间,下次使用sudo还要输入密码 sudo -b 在后台执行命令
Enter vim in the terminal to open the /etc/sudoers file.
Find the place as shown in the picture:
The content of the red box in the picture was added by myself later, where www is the user running php, and the default is in different environments The name will be different. My name under centos is www.
Users who can view the running of php can obtain it through the following php web page.
<?php echo shell_exec("id -a"); ?>
Look at the picture. There are three ALLs in each line. The first ALL represents the host in the network. The ALL in the second bracket represents the target user, indicating who is executing the command. The last ALL Represents the executable command name (you can specify the command you want the user to be able to execute).
NOPASSWD means no password is required. (For convenience, otherwise, if I access the program through a browser, there will be an extra step to fill in the password and wait for feedback. It is really troublesome, so it will be much easier)
If it is Ubuntu, there is no need to modify it. If it is Fedora If so, you still need to make some modifications.
Defaults Just open env_reset (that is, remove the # in front);
Check whether it is opened in the php.ini configuration file Safe mode
safe_mode = off 这样就可以了
There are multiple functions for php to execute Linux scripts, such as shell_exec(), system(), etc. I won’t introduce them here. Just use them. I use system ()function.
route.php
<?php $ip=(string)$_POST["ip"]; system("su ./route.sh $ip",$status); if($status == 'true') { echo "设置成功"; } else { echo "设置失败"; } ?>
After the previous settings are completed, after execution, the browser will display the setting as successful, indicating that the script was successfully executed.
1.php execution shell is actually executed by the user of Apache or Nginx, and php itself does not create a user.
2.Reprinted
Since I used to log in and operate as the root user in ECS every time, sudo was basically not used, but recently the project needs to do this: pass When the browser accesses the php web page, a script under Linux will be called and executed in the php web page. Originally, this matter was very simple, but when I actually operated it, I found that every time I accessed it through the browser, the script was not executed, and there was no problem when I executed the php web page through the command line in the terminal. I thought it was very different. Then I thought about it carefully and found that accessing through a browser is different from executing the initiator directly in the terminal. I thought it might be a problem with user permissions, so I checked online and found sudo. thing.
1. Introduction to sudo
sudo allows root to assign some rights that ordinary users do not have, so that ordinary users can also have relevant permissions of the root user (for example, sudo can be assigned to a certain user to execute certain commands. permissions).
One of the important files for sudo is /etc/sudoers. Which users have what kind of commands can be executed depends on this file. Mainly, only users assigned in it can use sudo.
sudo -l 列出该用户能执行的命令 sudo -u user 以指定用户来执行命令 sudo -k 清楚入场券上的时间,下次使用sudo还要输入密码 sudo -b 在后台执行命令
Enter vim in the terminal to open the /etc/sudoers file.
Find the place as shown in the picture:
The content of the red box in the picture was added by myself later, where www is the user running php, and the default is in different environments The name will be different. My name under centos is www.
Users who can view the running of php can obtain it through the following php web page.
<?php echo shell_exec("id -a"); ?>
Look at the picture. There are three ALLs in each line. The first ALL represents the host in the network. The ALL in the second bracket represents the target user, indicating who is executing the command. The last ALL Represents the executable command name (you can specify the command you want the user to be able to execute).
NOPASSWD means no password is required. (For convenience, otherwise, if I access the program through a browser, there will be an extra step to fill in the password and wait for feedback. It is really troublesome, so it will be much easier)
If it is Ubuntu, there is no need to modify it. If it is Fedora If so, you still need to make some modifications.
Defaults Just open env_reset (that is, remove the # in front);
Check whether it is opened in the php.ini configuration file Safe mode
safe_mode = off 这样就可以了
There are multiple functions for php to execute Linux scripts, such as shell_exec(), system(), etc. I won’t introduce them here. Just use them. I use system ()function.
route.php
<?php $ip=(string)$_POST["ip"]; system("su ./route.sh $ip",$status); if($status == 'true') { echo "设置成功"; } else { echo "设置失败"; } ?>
After the previous settings are completed, after execution, the browser will display the setting as successful, indicating that the script was successfully executed.
The php execution shell is actually executed by the user of Apache or Nginx, and php itself does not create a user.
related suggestion:
How does PHP solve the problem of not generating core files when executing shell scripts
Example of one-click installation of php7 by shell script
The above is the detailed content of PHP Analysis on Shell Script Permission Issues. For more information, please follow other related articles on the PHP Chinese website!

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

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

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

PHP is widely used in e-commerce, content management systems and API development. 1) E-commerce: used for shopping cart function and payment processing. 2) Content management system: used for dynamic content generation and user management. 3) API development: used for RESTful API development and API security. Through performance optimization and best practices, the efficiency and maintainability of PHP applications are improved.

PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7
