1 頁 (共 1 頁)

用PHP新增 Linux 上使用者帳號

文章發表於 : 週二 8月 14日, 2007年 6:06 pm
hardman
因為 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網管實驗室-螢火飛

文章發表於 : 週三 8月 15日, 2007年 1:07 pm
門神
蔡老大

你應該多貼一點

你學了不少ㄟ !!

貢獻一下吧 !!

Thank you !!