在php中使用 exec/ system/passthru/shell_exec 爬过的坑

本文介绍了一种在PHP框架中使用exec等函数调用外部命令遇到的问题及其解决方案。主要原因是执行用户权限不足导致无法正常获取内容。通过修改sudoers文件为特定用户授予执行命令的权限解决了这一问题。

问题描述

         在命令行中执行一个php/py文件,没有问题。

         当在php框架中用exec等函数调用外部命令时,发现怎么也得不到想要的内容,各种奇葩返回。

解决过程

         经查看,执行php时用户为www-data,权限过低,无法操作。

public function testtest(){
	    echo exec('whoami');die;
}

         www-data是默认运行web服务的用户/组,一般在通过apt安装web服务程序时生成。搭建web服务的文件夹/文件一般要设置成www-data的。

解决方法:

          1.sudo su               切换到root

          2.chmod u+w /etc/sudoers            赋予/etc/sudoers文件可写权限

          3.vim /etc/sudoers                 编辑sudoers文件                       

root    ALL=(ALL:ALL) ALL
www-data      ALL=(ALL)       NOPASSWD:ALL

          4.chmod u-w /etc/sudoers           去除/etc/sudoers文件可写权限

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值