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

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

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,

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

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

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.

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.
