轉(zhuǎn)帖|其它|編輯:郝浩|2010-07-19 13:54:45.000|閱讀 565 次
概述:在PHP中運(yùn)行只有root用戶才可以運(yùn)行的外部程序,一直是個(gè)老問題,用常規(guī)的辦法很難實(shí)現(xiàn)。這是因?yàn)橐话闱闆r下,PHP是作為APACHE的一個(gè)模塊的,也就是說,PHP是APACHE的一部分,而APACHE除了suEXEC機(jī)制外,是不能以不同的用戶ID來執(zhí)行命令的,但suEXEC機(jī)制只能CGI有效。
# 界面/圖表報(bào)表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
在PHP中運(yùn)行只有root用戶才可以運(yùn)行的外部程序,一直是個(gè)老問題,用常規(guī)的辦法很難實(shí)現(xiàn)。這是因?yàn)橐话闱闆r下,PHP是作為APACHE的一個(gè)模塊的,也就是說,PHP是APACHE的一部分,而APACHE除了suEXEC機(jī)制外,是不能以不同的用戶ID來執(zhí)行命令的,但suEXEC機(jī)制只能CGI有效。
網(wǎng)上曾經(jīng)有一篇文章,說用調(diào)用"su - -c COMMAND"可以實(shí)現(xiàn),但經(jīng)過多次試驗(yàn),發(fā)現(xiàn)不行,因?yàn)閟u命令必須在STDIN上輸入root的密碼。
怎么辦?用常規(guī)的方法難以奏效,只能再想其它的方法了。成功的關(guān)鍵在于能有一個(gè)可以切換用戶ID但又可以在命令上輸入密碼(或不用輸入密碼)的工具。有這樣的工具嗎?有,它就是super。
下面就具體說說如何來做?
要注意的是,安裝和配置super,都要以root身份來進(jìn)行。
第一步,切換到root下
第二步,安裝super
先下載super安裝包,其它包括了兩個(gè)工具:setuid和super,以及它們的文檔和man手冊。用下面的命令將它安裝到系統(tǒng)中:
#./configure # make && make install 從結(jié)果可以看到,兩個(gè)工具都將被安裝到/usr/local/bin目錄下。
第三步,配置super
super的配置文件是/etc/super.tab。這是一個(gè)文本文件,格式也比較復(fù)雜。不過,我們這里只要很簡單的加上幾行就可以了。至于詳細(xì)的說明,可以通過man super.tab來查看。
假設(shè)運(yùn)行Apache的用戶是nobody,我們欲通過super來增加系統(tǒng)用戶(調(diào)用useradd命令),那么我們只要在super.tab文件中加入以下這行:
auser /sbin/useradd nobody,hunte
第一段是super能夠識別的命令的別名;第二段是該別名所對應(yīng)的系統(tǒng)命令的全路徑;第三段是可以運(yùn)行該命令的用戶列表,用逗號分隔。這里除了nobody外,還一個(gè)叫hunte的普通用戶,是用于下面的測試。當(dāng)然,你應(yīng)該用你系統(tǒng)中有的任意一個(gè)普通用戶。
至此,super的配置就算好了。
第四步,測試
以第三步中指定的非nobody用戶登錄,運(yùn)行:
% /bin/super auser testuser
如果前面的配置沒什么錯(cuò)誤的話,用戶testuser應(yīng)該是成功地創(chuàng)建了。可以用:
% cat /etc/passwd | grep testuser
命令來驗(yàn)證一下。
第五步,在PHP中調(diào)用該命令
下面是PHP代碼:
<?
if ($username)
{
//應(yīng)該檢查新用戶是否已經(jīng)存在
echo '正在創(chuàng)建用戶<$username>...';
system(escapeshellcmd("/bin/super auser $username"));
}
?>
使用super,使得在PHP中以root身份運(yùn)行外部命令不再是難事。試試看吧。
測試環(huán)境:Centos + Apache + PHP 5.2.6
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉(zhuǎn)載自:網(wǎng)絡(luò)轉(zhuǎn)載