国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

在PHP中以root身份運行外部命令

2024-05-04 21:47:24
字體:
來源:轉載
供稿:網友

在PHP中運行只有root用戶才可以運行的外部程序,一直是個老問題,用常規的辦法很難實現,這是因為一般情況下,PHP是作為APACHE的一個模塊的,也就是說,PHP是APACHE的一部分,而APACHE除了suEXEC機制外,是不能以不同的用戶ID來執行命令的,但suEXEC機制只能CGI有效。

網上曾經有一篇文章,說用調用"su - -c COMMAND"可以實現,但經過多次試驗,發現不行,因為su命令必須在STDIN上輸入root的密碼。

怎么辦?用常規的方法難以奏效,只能再想其它的方法了。成功的關鍵在于能有一個可以切換用戶ID但又可以在命令上輸入密碼(或不用輸入密碼)的工具。有這樣的工具嗎?有,它就是super。

下面就具體說說如何來做?要注意的是,安裝和配置super,都要以root身份來進行。

第一步,切換到root下

第二步,安裝super

先到ftp://ftp.mdtsoft.com/pub/super下載super-3.14.0-1.i386.rpm。這是一個RPM文件,其它包括了兩個工具:setuid和super,以及它們的文檔和man手冊。用下面的命令將它安裝到系統中:

% rpm -Uvh super-3.14.0-1.i386.rpm

你還可以用這個命令來查看這個RPM中的文件:

% rpm -qpl super-3.14.0-1.i386.rpm

從結果可以看到,兩個工具都將被安裝到/bin目錄下。

第三步,配置super

super的配置文件是/etc/super.tab。這是一個文本文件,格式也比較復雜。不過,我們這里只要很簡單的加上幾行就可以了。至于詳細的說明,可以通過man super.tab來查看。

假設運行Apache的用戶是nobody,我們欲通過super來增加系統用戶(調用useradd命令),那么我們只要在super.tab文件中加入以下這行:

auser /sbin/useradd nobody,hunte

第一段是super能夠識別的命令的別名;第二段是該別名所對應的系統命令的全路徑

第三段是可以運行該命令的用戶列表,用逗號分隔。這里除了nobody外,還一個叫hunte的普通用戶,是用于下面的測試。當然,你應該用你系統中有的任意一個普通用戶。

至此,super的配置就算好了。

第四步,測試

以第三步中指定的非nobody用戶登錄,運行:

% /bin/super auser testuser

如果前面的配置沒什么錯誤的話,用戶testuser應該是成功地創建了,可以用:

% cat /etc/passwd | grep testuser

命令來驗證一下。

第五步,在PHP中調用該命令,下面是PHP代碼:

  1. <? 
  2. if($username
  3. //應該檢查新用戶是否已經存在 
  4. echo’正在創建用戶<$username>...’; 
  5. system(escapeshellcmd("/bin/superauser$username")); 
  6. ?> 

 

使用super,使得在PHP中以root身份運行外部命令不再是難事。試試看吧。

測試環境:RedHatLinux7.0(Kernel2.4.3)+Apache1.3.9+PHP4.0.4pl1

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 家居| 武清区| 龙江县| 唐山市| 娄烦县| 湘阴县| 繁昌县| 元阳县| 奉贤区| 广灵县| 泸水县| 哈密市| 阿克苏市| 栾城县| 江华| 漾濞| 木里| 永泰县| 陵水| 牙克石市| 巍山| 阳高县| 五寨县| 阳新县| 右玉县| 宿松县| 绥滨县| 巴林右旗| 苍山县| 资阳市| 日土县| 万宁市| 海丰县| 上蔡县| 仙游县| 伊宁县| 招远市| 洪雅县| 峨山| 湾仔区| 德阳市|