検索
ホームページphp教程php手册通过sudo解决php执行shell脚本的权限问题

通过sudo解决php执行shell脚本的权限问题

Jun 06, 2016 pm 07:42 PM
phpshellsudo埋め込む権限脚本解決する合格

由于以前在虚拟机中每次都是以root用户身份登录和进行操作,所以基本都没有用到sudo,但是最近项目需要要进行这么个事: 通过 浏览器访问php网页,php网页里会调用 执行 linux下的一个 脚本 。本来这个事很简单的,但是我在实际操作的时候,发现每次 通过 浏

由于以前在虚拟机中每次都是以root用户身份登录和进行操作,所以基本都没有用到sudo,但是最近项目需要要进行这么个事:通过浏览器访问php网页,php网页里会调用执行linux下的一个脚本。本来这个事很简单的,但是我在实际操作的时候,发现每次通过浏览器访问时,脚本都没有被执行,而我在终端里面通过命令行执行php网页确又是没有任何问题的,当时就觉得很差异,后来仔细想了想,通过浏览器访问和直接在终端里执行其发起者不一样,想想应该是用户权限问题,于是就上网查了查,结果就有了sudo这么回事。好了,说了一堆废话,下面来介绍下怎么用sudo解决上面的权限问题

1.sudo介绍

sudo允许root分配给普通用户一些不具备的权利,让普通用户也可以具有root用户的相关权限(比如说sudo可以分配给某一用户某些特定的命令执行权限)。

其中sudo一个重要的文件就是/etc/sudoers,哪些用户具有什么样的命令可以执行都是靠这个文件的,主要只有里面分配了的用户才能使用sudo。

sudo -l 列出该用户能<strong>执行</strong>的命令
sudo -u user 以指定用户来<strong>执行</strong>命令
sudo -k 清楚入场券上的时间,下次使用sudo还要输入密码
sudo -b 在后台<strong>执行</strong>命令
在终端里面输入visudo即可打开/etc/sudoers文件。

找到如图所示的地方

通过sudo解决php执行shell脚本的权限问题

图中红色方框的内容是我自己后来加的,其中daemon是php运行的用户,不同的环境下默认名字会不一样,我在fedora 9下的为daemon而在unbuntu中则不是这个名。

查看php运行的用户可以通过下面这个php网页获取。

<?php echo shell_exec("id -a");
?>

看图中每行都有三个ALL,第一个ALL代表网络中的主机,第二个括号里面的ALL代表目标用户,表示以谁的身份去执行命令,最后一个ALL代表的是可执行的命令名(可以指定你想要该用户能够执行的命令)。

其中NOPASSWD表示不用输入密码。(为了方便嘛,不然我通过浏览器访问难道程序里面多了道填写密码,还要等反馈,真是麻烦,这样就省事多了)

若是Ubuntu则不用再修改了,若是fedora 等则还需要进行一些修改,

Defaults    env_reset打开就可以了(即前面的#号去掉)

2.检查php.ini配置文件中是否打开了安全模式

safe_mode =  off 这样就可以了

php执行linux脚本的函数有多个,shell_exec()、system()等,这里也不多做介绍了,用就行了,我采用system()函数。

route.php

<?php $ip=(string)$_POST["ip"];
system("sudo ./route.sh $ip",$status);
if($status == &#39;true&#39;)
{
	echo "设置成功";
}
else
{
	echo "设置失败";
}
?>

前面设置妥当后,执行后,浏览器会显示设置成功,说明脚本成功执行

上面是网上找的其他人写的文章,我原封不动的拿来了,发现了一些个人认为不妥当的地方。

1.php执行shell实际是用的Apache或Nginx的用户去执行的,php本身不创建用户。

2.涉及到php代码中的路径问题,上面代码是不规范的,具体看我的另一篇文章


声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。