• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當(dāng)前位置:雨林木風(fēng)下載站 > 技術(shù)開(kāi)發(fā)教程 > 詳細(xì)頁(yè)面

        在PHP中以root身份運(yùn)行外部命令[轉(zhuǎn)自linuxaid]

        在PHP中以root身份運(yùn)行外部命令[轉(zhuǎn)自linuxaid]

        更新時(shí)間:2022-05-08 文章作者:未知 信息來(lái)源:網(wǎng)絡(luò) 閱讀次數(shù):

        Hunte 2001年4月15日

        在PHP中運(yùn)行只有root用戶(hù)才可以運(yùn)行的外部程序,一直是個(gè)老問(wèn)題,用常規(guī)的辦法很難實(shí)現(xiàn)。這是因?yàn)橐话闱闆r下,PHP是作為APACHE的一個(gè)模塊的,也就是說(shuō),PHP是APACHE的一部分,而APACHE除了suEXEC機(jī)制外,是不能以不同的用戶(hù)ID來(lái)執(zhí)行命令的,但suEXEC機(jī)制只能CGI有效。

        網(wǎng)上曾經(jīng)有一篇文章,說(shuō)用調(diào)用"su - -c COMMAND"可以實(shí)現(xiàn),但經(jīng)過(guò)多次試驗(yàn),發(fā)現(xiàn)不行,因?yàn)閟u命令必須在STDIN上輸入root的密碼。

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

        下面就具體說(shuō)說(shuō)如何來(lái)做?

        要注意的是,安裝和配置super,都要以root身份來(lái)進(jìn)行。

        第一步,切換到root下

        第二步,安裝super
        先到ftp://ftp.mdtsoft.com/pub/super下載super-3.14.0-1.i386.rpm。這是一個(gè)RPM文件,其它包括了兩個(gè)工具:setuid和super,以及它們的文檔和man手冊(cè)。用下面的命令將它安裝到系統(tǒng)中:
        % rpm -Uvh super-3.14.0-1.i386.rpm
        你還可以用這個(gè)命令來(lái)查看這個(gè)RPM中的文件:
        % rpm -qpl super-3.14.0-1.i386.rpm
        從結(jié)果可以看到,兩個(gè)工具都將被安裝到/bin目錄下。

        第三步,配置super
        super的配置文件是/etc/super.tab。這是一個(gè)文本文件,格式也比較復(fù)雜。不過(guò),我們這里只要很簡(jiǎn)單的加上幾行就可以了。至于詳細(xì)的說(shuō)明,可以通過(guò)man super.tab來(lái)查看。
        假設(shè)運(yùn)行Apache的用戶(hù)是nobody,我們欲通過(guò)super來(lái)增加系統(tǒng)用戶(hù)(調(diào)用useradd命令),那么我們只要在super.tab文件中加入以下這行:
        auser /sbin/useradd nobody,hunte
        第一段是super能夠識(shí)別的命令的別名;第二段是該別名所對(duì)應(yīng)的系統(tǒng)命令的全路徑;第三段是可以運(yùn)行該命令的用戶(hù)列表,用逗號(hào)分隔。這里除了nobody外,還一個(gè)叫hunte的普通用戶(hù),是用于下面的測(cè)試。當(dāng)然,你應(yīng)該用你系統(tǒng)中有的任意一個(gè)普通用戶(hù)。
        至此,super的配置就算好了。

        第四步,測(cè)試
        以第三步中指定的非nobody用戶(hù)登錄,運(yùn)行:
        % /bin/super auser testuser
        如果前面的配置沒(méi)什么錯(cuò)誤的話(huà),用戶(hù)testuser應(yīng)該是成功地創(chuàng)建了。可以用:
        % cat /etc/passwd | grep testuser
        命令來(lái)驗(yàn)證一下。

        第五步,在PHP中調(diào)用該命令
        下面是PHP代碼:
        <?
        if ($username)
        {
        //應(yīng)該檢查新用戶(hù)是否已經(jīng)存在
        echo '正在創(chuàng)建用戶(hù)<$username>...';
        system(escapeshellcmd("/bin/super auser $username"));
        }
        ?>
        使用super,使得在PHP中以root身份運(yùn)行外部命令不再是難事。試試看吧。
        測(cè)試環(huán)境:RedHat Linux 7.0 (Kernel 2.4.3) + Apache 1.3.9 + PHP 4.0.4pl1

        chpasswd.cgi是一個(gè)修改linux用戶(hù)密碼的cgi程序,彌補(bǔ)更改密碼需要兩次輸入密碼的缺陷

        溫馨提示:喜歡本站的話(huà),請(qǐng)收藏一下本站!

        本類(lèi)教程下載

        系統(tǒng)下載排行

        主站蜘蛛池模板: 无码不卡亚洲成?人片| 国产男女猛烈无遮挡免费网站| 亚洲精品偷拍视频免费观看| 国产va免费精品| 亚洲一区二区三区在线视频 | 一本无码人妻在中文字幕免费 | 亚洲成a人无码亚洲成www牛牛| 美女视频黄.免费网址| 中国内地毛片免费高清| 久久国产高潮流白浆免费观看| 免费黄色app网站| 国产亚洲一区二区三区在线不卡 | 国产亚洲美女精品久久| 中文字幕视频免费| 亚洲精品不卡视频| 免费夜色污私人影院网站电影| 国产h肉在线视频免费观看| 亚洲AⅤ视频一区二区三区| 一级做a爰片性色毛片免费网站| 日韩免费一区二区三区在线| 久久精品九九亚洲精品天堂| 亚洲午夜福利在线视频| 国产亚洲免费的视频看| 国产免费资源高清小视频在线观看| 亚洲国色天香视频| 日日麻批免费40分钟无码| 免费国产成人午夜电影| 亚洲不卡影院午夜在线观看| 久久午夜免费鲁丝片| 亚洲中文字幕无码一久久区| 免费人妻精品一区二区三区| 国产亚洲精品无码成人| 免费国产va在线观看| 亚洲AV成人无码久久精品老人| 美女巨胸喷奶水视频www免费| 亚洲高清无码综合性爱视频| 亚洲av日韩专区在线观看| 成人免费午夜视频| 亚洲人成图片网站| 亚洲中文字幕在线第六区| 国产在线观看麻豆91精品免费|