本文介紹如何使用PHP腳本修改Linux或Unix系統口令
需要的工具和安裝:
你必須安裝下面的工具和軟件:
– 修改口令的Shell腳本
– Sudo 訪問權
– Apache or Lighttpd web 服務器
– PHP服務端程序
步驟#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服務器的其它位置(用戶可讀):
$ cp chpasswd /var/www/
或者, 如果你使用Lighttpd web服務器:
$ cp chpasswd /home/lighttpd
步驟#2: 通過sudo以root身份執行命令
Apache或Lighttpd web服務器進入後台運行後會馬上使用非root權限. 這樣可以很好的防止口令修改, 就像passwd命令需要root權限才能修改其它用戶帳號的口令.
通常, Apache 2使用www-data用戶, Lighttpd使用lighttpd用戶(皆為普通用戶, 非root用戶). 使用root用戶登陸, 然後執行下面的命令:
# visudo
現在你的web服務器允許執行口令修改腳本(chpasswd). 如果你使用Apache web服務器, 執行下面的命令:
www-data ALL=NOPASSWD: /var/www/chpasswd
或者, 如果你使用Lighttpd web服務器, 執行下面的命令:
httpd ALL=NOPASSWD: /home/lighttpd/chpasswd
保存和退出文件.