萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> 使用PHP腳本修改Linux或Unix系統口令

使用PHP腳本修改Linux或Unix系統口令

   本文介紹如何使用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 “$passwordr” expect “assword:” send “$passwordr” 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保存和退出文件。  

   步驟3. 創建一個基於PHP的接口  現在你需要寫一個php腳本。這裡有一個php腳本實例。你可以根據你的需要來修   改。至少你需要正確設置好的shell腳本位置。打開php腳本和找到shellscript一行:  $shellscript = “sudo    /home/lighttpd/chpasswd”;修改shellscript指向到正確的位置。PHP的源代碼從這裡下載:  

   步驟4: 運行腳本  在你的web浏覽器地址欄輸入網地址 - https://mydomain.com/changepassword.php。你將會看到用   戶名和口令提示:  如果口令修改成功, 你會得到的確認提示:  由於一些原因, 如果口令修改失敗, 你可以參考下面提示   獲得更多詳細的錯誤信息:  

   步驟5: 安全  

   ◆永遠不要通過http協議直接運行上面的腳本. 而是使用https協議。  

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

   ◆永遠不要信任用戶的輸入。上面的php腳本只是一個例子。在現實的生產環境中, 你需要考慮采用更強大的用戶輸入確   認。討論PHP編程的安全超出了本文的范圍。你可以參考一本好的PHP書籍或者使用你喜歡的搜索引擎搜索相關的網站。

copyright © 萬盛學電腦網 all rights reserved