轉(zhuǎn)帖|其它|編輯:郝浩|2008-09-01 10:56:01.000|閱讀 1121 次
概述:使用PHP腳本修改Linux或Unix系統(tǒng)口令
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
需要的工具和安裝:
步驟1: 安裝可以修改用戶口令的shell腳本
該腳本可以實際用于修改Linux用戶的口令(已在Linux和FreeBSD測試)。
例子: shell腳本代碼
#!/bin/sh # \ exec expect -f “$0″ ${1+”$@”} set password [lindex $argv 1] spawn passwd [lindex $argv 0] sleep 1 expect “assword:” send “$password\r” expect “assword:” send “$password\r” expect eof
運行shell腳本(下載鏈接):
$ chpasswd username password
下載該腳本, 然后拷貝到你的web根目錄或者web服務(wù)器的其它位置(用戶可讀):
$ cp chpasswd /var/www/
或者, 如果你使用Lighttpd web服務(wù)器:
$ cp chpasswd /home/lighttpd
步驟2: 通過sudo以root身份執(zhí)行命令
Apache或Lighttpd web服務(wù)器進(jìn)入后臺運行后會馬上使用非root權(quán)限。這樣可以很好的防止口令修改, 就像passwd命令需要root權(quán)限才能修改其它用戶帳號的口令。
通常, Apache 2使用www-data用戶, Lighttpd使用lighttpd用戶(皆為普通用戶, 非root用戶)。使用root用戶登陸, 然后執(zhí)行下面的命令:
# visudo現(xiàn)在你的web服務(wù)器允許執(zhí)行口令修改腳本(chpasswd)。如果你使用Apache web服務(wù)器, 執(zhí)行下面的命令:
www-data ALL=NOPASSWD: /var/www/chpasswd
或者, 如果你使用Lighttpd web服務(wù)器, 執(zhí)行下面的命令:
httpd ALL=NOPASSWD: /home/lighttpd/chpasswd
保存和退出文件。
步驟3. 創(chuàng)建一個基于PHP的接口
現(xiàn)在你需要寫一個php腳本。這里有一個php腳本實例。你可以根據(jù)你的需要來修改。至少你需要正確設(shè)置好的shell腳本位置。打開php腳本和找到shellscript一行:
$shellscript = “sudo /home/lighttpd/chpasswd”;
修改shellscript指向到正確的位置。PHP的源代碼從這里下載:
步驟4: 運行腳本
在你的web瀏覽器地址欄輸入網(wǎng)地址 - //mydomain.com/changepassword.php。你將會看到用戶名和口令提示:
如果口令修改成功, 你會得到的確認(rèn)提示:
由于一些原因, 如果口令修改失敗, 你可以參考下面提示獲得更多詳細(xì)的錯誤信息:
步驟5: 安全
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉(zhuǎn)載自:中國站長站