因為 RedHat Apache Server 一般都是以 apache 這個 USER ID 執行,所以 PHP 執行時的身份也是 apache;但是管理使用者帳號的權利是 root,所以在 PHP 中是不能建立帳號的,除非可以暫時化身為 root 。
有一個指令 sudo 可以讓一般使用者以 root 身份執行某些指令,這些權限全部紀錄在 /etc/sudoers 中,如何設定不是我的重點,請自行 man sudoers 便知。
首先,查一下是否安裝了 sudo 這個套件
#rpm -qa | grep sudo
如果沒有的話,在光碟的 RPMS 目錄下有,勞駕自行安裝。
接著修改 /etc/sudoers 這個檔,但不要用 #vi 直接修改它,因為安全的理由,它被設成唯讀(readonly),請用 #visudo 去修改,增加一行在檔案最後面:
apache ALL=NOPASSWD:/usr/sbin/useradd
然後存檔,這一行的意思是當使用者 apache 執行 /usr/sbin/useradd 這個指令時,是以 root 身份執行的,而且不需要密碼。
接著再建立一個 Shell Script 我將它命名為 /sbin/createuser.sh
這個 Shell Script 內容如下:
#!/bin/sh
/usr/bin/sudo /usr/sbin/useradd -d /home/$1 -p $2 $1
存檔後,不要忘記將之改為可執行檔
#chmod 755 /sbin/createuser.sh
好了,這樣我們就可以在 PHP 中,利用 exec() 這個函數執行外部指令,來建立使用者帳號了。以下純粹是範例喔!可別真的照著做 ^_^
切換目錄到 Apache 的 DocumentRoot
#cd /var/www/html
建立一個 mkuser.php 內容是:
<?
$USERNAME = "abc" ; // 使用者名稱
$USERPASS = crypt( "1234" ) ; // 以 crypt 將密碼 "1234" 編碼
exec( "/sbin/createuser.sh $USERNAME $USERPASS" ) ;
?>
然後用瀏覽器開啟 http://您的網址/mkuser.php
回到系統 #ls -l /home
有沒有看到多出一個叫做 testuser 的使用者了吧 ^^ 原作者:PHP5網管實驗室-螢火飛