IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類(lèi)|軟件專(zhuān)題|手機(jī)版|論壇轉(zhuǎn)貼|軟件發(fā)布

您當(dāng)前所在位置:首頁(yè)網(wǎng)絡(luò)編程PHP編程 → 使用PHP腳本修改Linux或Unix系統(tǒng)口令

使用PHP腳本修改Linux或Unix系統(tǒng)口令

時(shí)間:2015/6/28來(lái)源:IT貓撲網(wǎng)作者:網(wǎng)管聯(lián)盟我要評(píng)論(0)

需要的工具和安裝:

你必須安裝下面的工具和軟件:


– 修改口令的Shell腳本;

– Sudo 訪問(wèn)權(quán);

Apache or Lighttpd web 服務(wù)器;

php服務(wù)端程序。

步驟1: 安裝可以修改用戶口令的shell腳本

該腳本可以實(shí)際用于修改Linux用戶的口令(已在Linux和FreeBSD測(cè)試)。

例子: 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

運(yùn)行shell腳本(下載鏈接):


$ chpasswd username password

下載該腳本, 然后拷貝到你的web根目錄或者web服務(wù)器的其它位置(用戶可讀):


$ cp chpasswd /var/www/

或者, 如果你使用Lighttpd web服務(wù)器:


$ cp chpasswd /home/lighttpd

步驟2: 通過(guò)sudo以root身份執(zhí)行命令

Apache或Lighttpd web服務(wù)器進(jìn)入后臺(tái)運(yùn)行后會(huì)馬上使用非root權(quán)限。這樣可以很好的防止口令修改, 就像passwd命令需要root權(quán)限才能修改其它用戶帳號(hào)的口令。

通常, 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)建一個(gè)基于PHP的接口

現(xiàn)在你需要寫(xiě)一個(gè)php腳本。這里有一個(gè)php腳本實(shí)例。你可以根據(jù)你的需要來(lái)修改。至少你需要正確設(shè)置好的shell腳本位置。打開(kāi)php腳本和找到shellscript一行:


$shellscript = "sudo /home/lighttpd/chpasswd";

修改shellscript指向到正確的位置。PHP的源代碼從這里下載:

步驟4: 運(yùn)行腳本

在你的web瀏覽器地址欄輸入網(wǎng)地址 - https://mydomain.com/changepassword.php。你將會(huì)看到用戶名和口令提示:

如果口令修改成功, 你會(huì)得到的確認(rèn)提示:

由于一些原因, 如果口令修改失敗, 你可以參考下面提示獲得更多詳細(xì)的錯(cuò)誤信息:

步驟5: 安全

◆永遠(yuǎn)不要通過(guò)http協(xié)議直接運(yùn)行上面的腳本. 而是使用https協(xié)議。

◆把腳本放入到受口令保護(hù)的目錄。

◆永遠(yuǎn)不要信任用戶的輸入。上面的php腳本只是一個(gè)例子。在現(xiàn)實(shí)的生產(chǎn)環(huán)境中, 你需要考慮采用更強(qiáng)大的用戶輸入確認(rèn)。討論P(yáng)HP編程的安全超出了本文的范圍。你可以參考一本好的PHP書(shū)籍或者使用你喜歡的搜索引擎搜索相關(guān)的網(wǎng)站。

關(guān)鍵詞標(biāo)簽:系統(tǒng),口令,修改,腳本,

相關(guān)閱讀

文章評(píng)論
發(fā)表評(píng)論

熱門(mén)文章 plsql developer怎么連接數(shù)據(jù)庫(kù)-plsql deveplsql developer怎么連接數(shù)據(jù)庫(kù)-plsql deve2021年最好用的10款php開(kāi)發(fā)工具推薦2021年最好用的10款php開(kāi)發(fā)工具推薦在 PHP 中使用命令行工具在 PHP 中使用命令行工具php應(yīng)用程序安全防范技術(shù)研究php應(yīng)用程序安全防范技術(shù)研究

相關(guān)下載

人氣排行 詳解ucenter原理及第三方應(yīng)用程序整合思路、方法PHP中防止SQL注入攻擊PHP會(huì)話Session的具體使用方法解析PHP運(yùn)行出現(xiàn)Notice : Use of undefined constant 的解決辦法CakePHP程序員必須知道的21條技巧PHP采集圖片實(shí)例(PHP采集)PHP如何清空mySQL數(shù)據(jù)庫(kù)plsql developer怎么連接數(shù)據(jù)庫(kù)-plsql developer連接數(shù)據(jù)庫(kù)方法