使用PHP腳本修改Linux或Unix系統(tǒng)口令_PHP教程
推薦:給wordpress 增加干擾碼防采集打開(kāi) wp-includes下的post-template.php 先將代碼加到 post-template.php 第一行 function RndString($body) { //最大間隔距離(如果在檢測(cè)不到p標(biāo)
需要的工具和安裝:
你必須安裝下面的工具和軟件:
– 修改口令的Shell腳本; – Sudo 訪問(wèn)權(quán); – Apache or Lighttpd web 服務(wù)器; – PHP服務(wù)端程序。 |
步驟1: 安裝可以修改用戶(hù)口令的shell腳本
該腳本可以實(shí)際用于修改Linux用戶(hù)的口令(已在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ù)器的其它位置(用戶(hù)可讀):
|
|
或者, 如果你使用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ù)帳號(hào)的口令。
通常, Apache 2使用www-data用戶(hù), Lighttpd使用lighttpd用戶(hù)(皆為普通用戶(hù), 非root用戶(hù))。使用root用戶(hù)登陸, 然后執(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ì)看到用戶(hù)名和口令提示:
如果口令修改成功, 你會(huì)得到的確認(rèn)提示:
由于一些原因, 如果口令修改失敗, 你可以參考下面提示獲得更多詳細(xì)的錯(cuò)誤信息:
步驟5: 安全
◆永遠(yuǎn)不要通過(guò)http協(xié)議直接運(yùn)行上面的腳本. 而是使用https協(xié)議。
◆把腳本放入到受口令保護(hù)的目錄。
◆永遠(yuǎn)不要信任用戶(hù)的輸入。上面的php腳本只是一個(gè)例子。在現(xiàn)實(shí)的生產(chǎn)環(huán)境中, 你需要考慮采用更強(qiáng)大的用戶(hù)輸入確認(rèn)。討論P(yáng)HP編程的安全超出了本文的范圍。你可以參考一本好的PHP書(shū)籍或者使用你喜歡的搜索引擎搜索相關(guān)的網(wǎng)站。
分享:php使用curl模擬用戶(hù)登陸bool curl_setopt (int ch, string option, mixed value) curl_setopt()函數(shù)將為一個(gè)CURL會(huì)話設(shè)置選項(xiàng)。option參數(shù)是你想要的設(shè)置,value是這個(gè)選項(xiàng)給定的值。 下列選項(xiàng)的值將被作為長(zhǎng)整形
- PHPNOW安裝Memcached擴(kuò)展方法詳解
- php記錄頁(yè)面代碼執(zhí)行時(shí)間
- PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼
- apache設(shè)置靜態(tài)文件緩存方法介紹
- php對(duì)圖像的各種處理函數(shù)代碼小結(jié)
- PHP 關(guān)于訪問(wèn)控制的和運(yùn)算符優(yōu)先級(jí)介紹
- 關(guān)于PHP語(yǔ)言構(gòu)造器介紹
- php/js獲取客戶(hù)端mac地址的實(shí)現(xiàn)代碼
- php5.5新數(shù)組函數(shù)array_column使用
- PHP preg_match的匹配多國(guó)語(yǔ)言的技巧
- php 中序列化和json使用介紹
- php采集文章中的圖片獲取替換到本地
PHP教程Rss訂閱編程教程搜索
PHP教程推薦
- PHP 5.0對(duì)象模型深度探索之類(lèi)的靜態(tài)成員
- 十天學(xué)會(huì)php之第八天
- 童虎:人人皆可做插件 Discuz! 插件開(kāi)發(fā)實(shí)例講解
- PHP utf-8編碼問(wèn)題,utf8編碼,數(shù)據(jù)庫(kù)亂碼,頁(yè)面顯示輸出亂碼
- 創(chuàng)建論壇專(zhuān)業(yè)知識(shí)庫(kù) HDWiki(For Discuz!)V1.0正式版發(fā)布
- PHP Tokenizer 的學(xué)習(xí)筆記
- 克隆一個(gè)新項(xiàng)目的快捷方式
- PHP教程之采集百度音樂(lè)程序
- 如何使用PHP中的字符串函數(shù)
- php 目錄遍歷、刪除 函數(shù)的使用介紹
- 相關(guān)鏈接:
- 教程說(shuō)明:
PHP教程-使用PHP腳本修改Linux或Unix系統(tǒng)口令
。