PHP HTTP 認(rèn)證實(shí)例詳解
HP來(lái)實(shí)現(xiàn)HTTP的強(qiáng)制認(rèn)證是十分簡(jiǎn)單的,只需簡(jiǎn)單的幾行代碼就可以實(shí)現(xiàn),下面我們來(lái)看一個(gè)例子,然后結(jié)合這里例子我向大家詳細(xì)介紹一下PHP實(shí)現(xiàn)HTTP認(rèn)證。
<?php if(!isset($_SERVER['PHP_AUTH_USER'])) { header('WWW-Authenticate: Basic realm="系統(tǒng)名稱"'); header('HTTP/1.0 401 Unauthorized'); echo '未通過(guò)HTTP認(rèn)證.'; exit; } else { echo '認(rèn)證通過(guò).'; echo '用戶名: '.$_SERVER['PHP_AUTH_USER']."\n"; echo '密碼: '.$_SERVER['PHP_AUTH_PW']."\n"; } ?>
1.實(shí)現(xiàn)說(shuō)明
怎么樣,看到上面的代碼了吧,就這么幾行添加到你的程序頁(yè)面上就可以實(shí)現(xiàn)了.
它是通過(guò)利用header()函數(shù)向客戶端瀏覽器發(fā)送”Authentication Required”信息,強(qiáng)制其彈出一個(gè)用戶名/密碼輸入窗口,當(dāng)用戶輸入用戶名和密碼后,包含有URL的PHP腳本將會(huì)加上預(yù)定義變量PHP_AUTH_USER, PHP_AUTH_PW和AUTH_TYPE然后再次調(diào)用,這三個(gè)變量分別表示用戶名,密碼和認(rèn)證類型(從PHP5.0.1起開始支持”Basic”和”Digest”兩種認(rèn)證方式),它們被保存在$_SERVER(從HP>>4.1.0起有效)或$HTTP_SERVER_VARS(從PHP3起有效)數(shù)組中具體應(yīng)用時(shí),我們可以把驗(yàn)證的幾行代碼寫成函數(shù),只要判斷到用戶變量不存在或驗(yàn)證不正確就一直執(zhí)行該函數(shù)并彈出窗口,而且還可以設(shè)置錯(cuò)誤登錄幾次就不允許該用戶訪問(wèn),具體的使用大家使勁的發(fā)散思考吧.
2.注意事項(xiàng):
1.這段代碼必須放到程序的開始,且在其開始執(zhí)行之前不能有任何輸出(若有輸出則需要使用輸出緩沖函數(shù)才行).
2.PHP的HTTP認(rèn)證機(jī)制僅在PHP以Apache模塊方式運(yùn)行時(shí)才有效,這個(gè)容易理解,它本身是HTTP強(qiáng)制認(rèn)證,肯定是不適合于CGI版本,不能在命令行下執(zhí)行的.
3.header發(fā)送標(biāo)頭代碼時(shí)請(qǐng)小心.為了對(duì)所有的客戶端保證兼容性,關(guān)鍵字”Basic”的第一個(gè)字母必須大寫為”B”,分界字符串必須用雙引號(hào)引用(不能是單引號(hào));在HTTP/1.0和401之間必須有且僅有一個(gè)空格.
4.在上面列子中,僅輸出了用戶名和密碼,而在實(shí)際系統(tǒng)中則可按照登錄驗(yàn)證流程進(jìn)行與數(shù)據(jù)庫(kù)或其他方式進(jìn)行判斷和驗(yàn)證.
5.從PHP4.3.0起,為防止有人通過(guò)編寫腳本來(lái)從頁(yè)面上獲取密碼,當(dāng)外部認(rèn)證對(duì)特定頁(yè)面有效,并且安全模式被開啟時(shí),PHP_AUTH變量將不會(huì)被設(shè)置.可以用REMOTE_USER來(lái)辨別外部認(rèn)證的用戶,用AuthType指令來(lái)判斷外部認(rèn)證機(jī)制是否有效.
6.要想讓HTTP認(rèn)證能夠在IIS下工作,PHP配置選項(xiàng)cgi.rfc2616_headers必須設(shè)置為0(默認(rèn)值).
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- PHP中基本HTTP認(rèn)證技巧分析
- 重新封裝zend_soap實(shí)現(xiàn)http連接安全認(rèn)證的php代碼
- 使用PHP模擬HTTP認(rèn)證
- PHP使用socket發(fā)送HTTP請(qǐng)求的方法
- PHP中Http協(xié)議post請(qǐng)求參數(shù)
- PHP中file_get_contents函數(shù)抓取https地址出錯(cuò)的解決方法(兩種方法)
- PHP實(shí)現(xiàn)HTTP斷點(diǎn)續(xù)傳的方法
- php curl 獲取https請(qǐng)求的2種方法
- php使用curl訪問(wèn)https示例分享
- php之curl實(shí)現(xiàn)http與https請(qǐng)求的方法
- php下通過(guò)偽造http頭破解防盜鏈的代碼
相關(guān)文章
PHP迭代器實(shí)現(xiàn)斐波納契數(shù)列的函數(shù)
斐波納契數(shù)列通常做法是用遞歸實(shí)現(xiàn),當(dāng)然還有其它的方法。這里現(xiàn)學(xué)現(xiàn)賣,用PHP的迭代器來(lái)實(shí)現(xiàn)一個(gè)斐波納契數(shù)列,幾乎沒有什么難度,只是把類里的next()方法重寫了一次。注釋已經(jīng)寫到代碼中,也是相當(dāng)好理解的2013-11-11PHP 計(jì)算兩個(gè)特別大的整數(shù)實(shí)例代碼
這篇文章主要介紹了PHP 計(jì)算兩個(gè)特別大的整數(shù)實(shí)例代碼,需要的朋友可以參考下2018-05-05php生成靜態(tài)頁(yè)面并實(shí)現(xiàn)預(yù)覽功能
這篇文章主要為大家詳細(xì)介紹了php生成靜態(tài)頁(yè)面并實(shí)現(xiàn)預(yù)覽功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06php源碼 fsockopen獲取網(wǎng)頁(yè)內(nèi)容實(shí)例詳解
這篇文章主要介紹了php源碼 fsockopen獲取網(wǎng)頁(yè)內(nèi)容實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2016-09-09cakephp2.X多表聯(lián)合查詢join及使用分頁(yè)查詢的方法
這篇文章主要介紹了cakephp2.X多表聯(lián)合查詢join及使用分頁(yè)查詢的方法,結(jié)合實(shí)例形式簡(jiǎn)單分析了cakephp查詢及分頁(yè)操作相關(guān)技巧,需要的朋友可以參考下2017-02-02php 404錯(cuò)誤頁(yè)面實(shí)現(xiàn)代碼
如果訪問(wèn)您站點(diǎn)的用戶由于各種原因暫時(shí)出現(xiàn)無(wú)法訪問(wèn)頁(yè)面的錯(cuò)誤,如何給他一個(gè)友好的答復(fù),并且你也知道發(fā)生了這個(gè)錯(cuò)誤,看看下面這段程序,是用來(lái)定制404錯(cuò)誤頁(yè)面和發(fā)通知給網(wǎng)管。2009-06-06