程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 通過PHP修改Linux或Unix口令的方法分享

通過PHP修改Linux或Unix口令的方法分享

編輯:關於PHP編程

需要的工具和安裝:

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

  –修改口令的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保存和退出文件。

  步驟3.創建一個基於PHP的接口

  現在你需要寫一個php腳本。這裡有一個php腳本實例。你可以根據你的需要來修改。至少你需要正確設置好的shell腳本位置。打開php腳本和找到shellscript一行:

  $shellscript = “sudo /home/lighttpd/chpasswd”;修改shellscript指向到正確的位置。PHP的源代碼從這裡下載:

  步驟4:運行腳本

  在你的web浏覽器地址欄輸入網地址,你將會看到用戶名和口令提示:

  如果口令修改成功,你會得到的確認提示:

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

  步驟5:安全

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

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

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved