如何配置服务器的php,使得能成功运行exec函数?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何配置服务器的php,使得能成功运行exec函数?相关的知识,希望对你有一定的参考价值。

已经将exec函数从php.ini的禁止运行的函数列表中删除了,要重启服务器才能生效吗?如何重启?
exec函数运行的服务器上的命令行,必须放在指定的安全目录才能运行吗?安全目录在哪里?如何添加自己的安全目录?默认的安全目录在哪里?如何配置?

如果是命令行使用的话,直接运行即可,如果是apache使用的话,需要重启apache,如果是nginx配合使用的话,需要重启php-fpm,exec函数执行命令并不需要安全目录,只要有执行权限就可以执行。 参考技术A 修改php.ini后是否需要重启服务器与PHP的工作模式相关,如果是CGI方式工作无需任何重启,如果是以APACHE模块方式需要重启APACHE服务,重启的方法与服务器的操作系统相关,WINDOWS类服务器可以在系统管理、服务里面点鼠标选择重启,LINUX可以使用命令httpd -k restart。如果PHP是以FASTCGI方式工作,需要重启FPM即可。
如果exec可以执行,一般不存在安全目录限制,只是进程和文件的权限匹配即可。
以上回复比较宽泛,甚至说都是猜测着的,如果需要具体打什么命令、哪里点鼠标、修改哪个文件,需要一步一步的分析,少不了要上图片。

PHP在Linux下Apache环境中执行exec,system,passthru等服务器命令函数

若在服务器中使用php test.php运行exec,system,passthru等命令相关的脚本能成功运行,在web页面却没反应,则
查看下apache的error_log日志,一般是这几个函数

system() has been disabled for se
curity reasons in /var/www/html/test.php on line 34

报错了。

看下php.ini中的disable_functions 有没有禁用了这些函数,删除禁用后保存。

重启下php和Apache即可。

 
 
 
有时候为了安全我们需要禁掉一些PHP危险函数:
 
phpinfo() 
功能描述:输出 PHP 环境信息以及相关的模块、WEB 环境等信息。 
危险等级:中 

passthru() 
功能描述:允许执行一个外部程序并回显输出,类似于 exec()。 
危险等级:高 

exec() 
功能描述:允许执行一个外部程序(如 UNIX Shell 或 CMD 命令等)。 
危险等级:高 

system() 
功能描述:允许执行一个外部程序并回显输出,类似于 passthru()。 
危险等级:高 

chroot() 
功能描述:可改变当前 PHP 进程的工作根目录,仅当系统支持 CLI 模式 
PHP 时才能工作,且该函数不适用于 Windows 系统。 
危险等级:高 

scandir() 
功能描述:列出指定路径中的文件和目录。 
危险等级:中 

chgrp() 
功能描述:改变文件或目录所属的用户组。 
危险等级:高 

chown() 
功能描述:改变文件或目录的所有者。 
危险等级:高 

shell_exec() 
功能描述:通过 Shell 执行命令,并将执行结果作为字符串返回。 
危险等级:高 

proc_open() 
功能描述:执行一个命令并打开文件指针用于读取以及写入。 
危险等级:高 

proc_get_status() 
功能描述:获取使用 proc_open() 所打开进程的信息。 
危险等级:高 

error_log() 
功能描述:将错误信息发送到指定位置(文件)。 
安全备注:在某些版本的 PHP 中,可使用 error_log() 绕过 PHP safe mode, 
执行任意命令。 
危险等级:低 

ini_alter() 
功能描述:是 ini_set() 函数的一个别名函数,功能与 ini_set() 相同。 
具体参见 ini_set()。 
危险等级:高 

ini_set() 
功能描述:可用于修改、设置 PHP 环境配置参数。 
危险等级:高 

ini_restore() 
功能描述:可用于恢复 PHP 环境配置参数到其初始值。 
危险等级:高 

dl() 
功能描述:在 PHP 进行运行过程当中(而非启动时)加载一个 PHP 外部模块。 
危险等级:高 

pfsockopen() 
功能描述:建立一个 Internet 或 UNIX 域的 socket 持久连接。 
危险等级:高 

syslog() 
功能描述:可调用 UNIX 系统的系统层 syslog() 函数。 
危险等级:中 

readlink() 
功能描述:返回符号连接指向的目标文件内容。 
危险等级:中 

symlink() 
功能描述:在 UNIX 系统中建立一个符号链接。 
危险等级:高 

popen() 
功能描述:可通过 popen() 的参数传递一条命令,并对 popen() 所打开的文件进行执行。 
危险等级:高 

stream_socket_server() 
功能描述:建立一个 Internet 或 UNIX 服务器连接。 
危险等级:中 

putenv() 
功能描述:用于在 PHP 运行时改变系统字符集环境。在低于 5.2.6 版本的 PHP 中,可利用该函数 
修改系统字符集环境后,利用 sendmail 指令发送特殊参数执行系统 SHELL 命令。 
危险等级:高 

禁用方法如下: 
打开/etc/php.ini文件, 
查找到 disable_functions ,添加需禁用的函数名,如下: 
phpinfo,eval,passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,pfsockopen,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket,fsockopen
 
 





































































































以上是关于如何配置服务器的php,使得能成功运行exec函数?的主要内容,如果未能解决你的问题,请参考以下文章

如何让exec自己运行,php页面继续运行,让PHP不再阻塞

php exec()

如何让php执行shell

LINUX+NGINX下的PHP shell_exec()函数执行linux命令 2019-08-08

如何解决php执行exec函数ffmpeg命令不生效的问题

raspberry pi-php-exec