• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

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

    發布: 2007-7-14 19:53 | 作者: 佚名    | 來源: 網絡轉載     | 查看: 8次 | 進入軟件測試論壇討論

    領測軟件測試網 在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代碼:
    <?
    if ($username)
    {
    //應該檢查新用戶是否已經存在
    echo '正在創建用戶<$username>...';
    system(escapeshellcmd("/bin/super auser $username"));
    }
    ?>
    使用super,使得在PHP中以root身份運行外部命令不再是難事。試試看吧。
    測試環境:RedHat Linux 7.0 (Kernel 2.4.3) + Apache 1.3.9 + PHP 4.0.4pl1

    chpasswd.cgi是一個修改linux用戶密碼的cgi程序,彌補更改密碼需要兩次輸入密碼的缺陷

    文章來源于領測軟件測試網 http://www.kjueaiud.com/


    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>