电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

實例學習PHP程序對用戶身份認證實現兩種方法

瀏覽:3日期:2024-02-24 08:08:57

用戶在設計和維護站點的時候,經常需要限制對某些重要文件或信息的訪問。通常,我們可以采用內置于WEB服務器的基于HTTP協議的用戶身份驗證機制。當訪問者瀏覽受保護頁面時,客戶端瀏覽器會彈出對話窗口要求用戶輸入用戶名和密碼,對用戶的身份進行驗證,以決定用戶是否有權訪問頁面。下面用兩種方法來說明其實現原理。

一、用HTTP標頭來實現

標頭是服務器以HTTP協議傳送HTML信息到瀏覽器前所送出的字串。HTTP采用一種挑戰/響應模式對試圖進入受密碼保護區域的用戶進行身份驗證。具體來說,當用戶首次向WEB服務器發出訪問受保護區域的請求時,挑戰進程被啟動,服務器返回特殊的401標頭,表明該用戶身份未經驗證??蛻舳藶g覽器在檢測到上述響應之后自動彈出對話框,要求用戶輸入用戶名和密碼。用戶完成輸入之后點擊確定,其身份識別信息就被傳送到服務端進行驗證。如果用戶輸入的用戶名和密碼有效,WEB服務器將允許用戶進入受保護區域,并且在整個訪問過程中保持其身份的有效性。相反,若用戶輸入的用戶名稱或密碼無法通過驗證,客戶端瀏覽器會不斷彈出輸入窗口要求用戶再次嘗試輸入正確的信息。整個過程將一直持續到用戶輸入正確的信息位置,也可以設定允許用戶進行嘗試的最大次數,超出時將自動拒絕用戶的訪問請求。

在PHP腳本中,使用函數header()直接給客戶端的瀏覽器發送HTTP標頭,這樣在客戶端將會自動彈出用戶名和密碼輸入窗口,來實現我們的身份認證功能。在PHP中,客戶端用戶輸入的信息傳送到服務器之后自動保存在 $PHP_AUTH_USER,$PHP_AUTH_PW,以及 $PHP_AUTH_TYPE這三個全局變量中。利用這三個變量,我們可以根據保存在數據文件或者數據庫中用戶帳號信息來驗證用戶身份!

不過,需要提醒使用者注意的是:只有在以模塊方式安裝的PHP中才能使用$PHP_AUTH_USER,$PHP_AUTH_PW,以及 $PHP_AUTH_TYPE這三個變量。如果用戶使用的是CGI模式的PHP則無法實現驗證功能。在本節后附有PHP的模塊方式安裝方法。

下面我們用Mysql數據庫來存儲用戶的身份。我們需要從數據庫中提取每個帳號的用戶名和密碼以便與$PHP_AUTH_USER和$PHP_AUTH_PW變量進行比較,判斷用戶的真實性。

首先,在MySql中建立一個存放用戶信息的數據庫

數據庫名為XinXiKu ,表名為user;表定義如下:

create table user(ID INT(4) NOT NULL AUTO_INCREMENT,name VARCHAR(8) NOT NULL,password CHAR(8) NOT NULL,PRIMARY KEY(ID))

說明:

1、ID為一個序列號,不為零而且自動遞增,為主鍵;

2、name為用戶名,不能為空;

3、password為用戶密碼,不能為空;

以下是用戶驗證文件login.php

//判斷用戶名是否設置if(!isset($PHP_AUTH_USER)) {header('WWW-Authenticate:Basic realm='身份驗證功能'');header('HTTP/1.0 401 Unauthorized');echo '身份驗證失敗,您無權共享網絡資源!';exit();}/*連接數據庫*/$db=mysql_connect('localhost','root','');//選擇數據庫mysql_select_db('XinXiKu',$db);//查詢用戶是否存在$result=mysql_query('SELECT * FROM user where name='$PHP_AUTH_USER' and password='$PHP_AUTH_PW'',$db);if ($myrow = mysql_fetch_row($result)) {//以下為身份驗證成功后的相關操作...} else {//身份驗證不成功,提示用戶重新輸入header('WWW-Authenticate:Basic realm='身份驗證功能'');header('HTTP/1.0 401 Unauthorized');echo '身份驗證失敗,您無權共享網絡資源!';exit();}?>

程序說明:

在程序中,首先檢查變量$PHP_AUTH_USER是否已經設置。如果沒有設置,說明需要驗證,腳本發出HTTP 401錯誤號頭標,告訴客戶端的瀏覽器需要進行身份驗證,由客戶端的瀏覽器彈出一個身份驗證窗口,提示用戶輸入用戶名和密碼,輸入完成后,連接數據庫,查詢該用用戶名及密碼是否正確,如果正確,允許登錄進行相關操作,如果不正確,繼續要求用戶輸入用戶名和密碼。

函數說明:

1、isset():用于確定某個變量是否已被賦值。根據變量值是否存在,返回true或false

2、header():用于發送特定的HTTP標頭。注意,使用header()函數時,一定要在任何產生實際輸出的HTML或PHP代碼前面調用該函數。

3、mysql_connect():打開 MySQL 服務器連接。

4、mysql_db_query():送查詢字符串 (query) 到 MySQL 數據庫。

5、mysql_fetch_row():返回單列的各字段。

二、用session實現服務器驗證

對于需要身份驗證的頁面,使用apache服務器驗證是最好不過的了。但是,apache服務器驗證的界面不夠友好。而且,cgi模式的 php,iis下的php,都不能使用apache服務器驗證。這樣,我們可以利用session在不同頁面間保存用戶身份,達到身份驗證的目的。

在后端我們同樣利用上面的Mysql數據庫存放用戶信息。

我們先編寫一個用戶登錄界面,文件名為login.php,代碼職下:

____________________________________________________________

<form action='login1.php'>

用戶名:<input type='text' name='name'><br>

口 令:<input type='text' name='pass'><br>

<input type='submit' value='登錄'>

</form>

____________________________________________________________

login1.php處理提交的表單,代碼如下:

$db=mysql_connect('localhost','root','');mysql_select_db('XinXiKu',$db);$result=mysql_query('SELECT * FROM user where name='$name' and password='$pass'',$db);if ($myrow = mysql_fetch_row($result)) {//注冊用戶session_start();session_register('user');$user=$myrow['user'];// 身份驗證成功,進行相關操作...} else {echo'身份驗證失敗,您無權共享網絡資源!';}?>這里需要說明的是,用戶可以使用在后續的操作中用**http://domainname/next.php?user=用戶名 **來繞過身份驗證。所以,后續的操作應先檢查變量是否注冊:已注冊,則進行相應操作,否則視為非法登錄。相關代碼如下:session_start();if (!session_is_registered('user')){echo '身份驗證失敗,屬于非法登錄!';} else {//成功登錄進行相關操作...}?>

附錄:PHP以模塊方式安裝方法

1、首先下載文件:mod_php4-4.0.1-pl2。[如果你的不是PHP4,那么就趕快升級吧!]

解開后有三個文件:mod_php4.dll、mod_php4.conf、readme.txt

2、相關文件拷貝

把mod_php4.dll拷貝到apache安裝目錄的modules目錄下面

把mod_php4.conf拷貝到apache安裝目錄的conf目錄下面

把msvcrt.dll文件拷貝到apache的安裝目錄下面

3、打開conf/srm.conf文件 ,在其中加上一句

Include conf/mod_php4.conf

在做這一些之前請把您的httpd.conf中關于CGI模式的所以設置語句都去掉,即類似下面的部分!

ScripAlias /php4/ 'C:/php4/'AddType application/x-httpd-php4 .phpAddType application/x-httpd-php4 .php3AddType application/x-httpd-php4 .php4Action application/x-httpd-php4 /php4/php.exe

要想使PHP支持更多的后綴名,沒問題。在給出的配置文件mod_php4.conf已經支持了三種后綴名php,php3,php4,如果你還想支持更多的后綴名可以更改這個文件,很簡單的。

4、測試

用<? phpinfo(); ?> 測試。會看到Server API的值為apache,而不是cgi ,而且還有有關HTTP Headers Information的信息。

標簽: PHP
主站蜘蛛池模板: 酒糟烘干机-豆渣烘干机-薯渣烘干机-糟渣烘干设备厂家-焦作市真节能环保设备科技有限公司 | 网站建设,北京网站建设,北京网站建设公司,网站系统开发,北京网站制作公司,响应式网站,做网站公司,海淀做网站,朝阳做网站,昌平做网站,建站公司 | 铝镁锰板厂家_进口钛锌板_铝镁锰波浪板_铝镁锰墙面板_铝镁锰屋面-杭州军晟金属建筑材料 | 塑胶跑道施工-硅pu篮球场施工-塑胶网球场建造-丙烯酸球场材料厂家-奥茵 | RTO换向阀_VOC高温阀门_加热炉切断阀_双偏心软密封蝶阀_煤气蝶阀_提升阀-湖北霍科德阀门有限公司 | ICP备案查询_APP备案查询_小程序备案查询 - 备案巴巴 | 杭州翻译公司_驾照翻译_专业人工翻译-杭州以琳翻译有限公司官网 组织研磨机-高通量组织研磨仪-实验室多样品组织研磨机-东方天净 | 海外仓系统|国际货代系统|退货换标系统|WMS仓储系统|海豚云 | 企业管理培训,企业培训公开课,企业内训课程,企业培训师 - 名课堂企业管理培训网 | 缝纫客| 河南新乡德诚生产厂家主营震动筛,振动筛设备,筛机,塑料震动筛选机 | 钢化玻璃膜|手机钢化膜|钢化膜厂家|手机保护膜-【东莞市大象电子科技有限公司】 | 老城街小面官网_正宗重庆小面加盟技术培训_特色面馆加盟|牛肉拉面|招商加盟代理费用多少钱 | 废旧物资回收公司_广州废旧设备回收_报废设备物资回收-益美工厂设备回收公司 | 西门子伺服控制器维修-伺服驱动放大器-828D数控机床维修-上海涌迪 | 自清洗过滤器_全自动过滤器_全自动反冲洗过滤器_量子过滤器-滑漮滴 | 石油/泥浆/不锈钢防腐/砂泵/抽砂泵/砂砾泵/吸砂泵/压滤机泵 - 专业石油环保专用泵厂家 | 欧盟ce检测认证_reach检测报告_第三方检测中心-深圳市威腾检验技术有限公司 | 数年网路-免费在线工具您的在线工具箱-shuyear.com | 爆破器材运输车|烟花爆竹运输车|1-9类危险品厢式运输车|湖北江南专用特种汽车有限公司 | 集菌仪厂家_全封闭_封闭式_智能智能集菌仪厂家-上海郓曹 | 陕西视频监控,智能安防监控,安防系统-西安鑫安5A安防工程公司 | 半自动预灌装机,卡式瓶灌装机,注射器灌装机,给药器灌装机,大输液灌装机,西林瓶灌装机-长沙一星制药机械有限公司 | 郑州宣传片拍摄-TVC广告片拍摄-微电影短视频制作-河南优柿文化传媒有限公司 | 石家庄网站建设|石家庄网站制作|石家庄小程序开发|石家庄微信开发|网站建设公司|网站制作公司|微信小程序开发|手机APP开发|软件开发 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 运动木地板_体育木地板_篮球馆木地板_舞台木地板-实木运动地板厂家 | 硬度计_影像测量仪_维氏硬度计_佛山市精测计量仪器设备有限公司厂家 | 2025世界机器人大会_IC China_半导体展_集成电路博览会_智能制造展览网 | 在线浊度仪_悬浮物污泥浓度计_超声波泥位计_污泥界面仪_泥水界面仪-无锡蓝拓仪表科技有限公司 | 工业插头-工业插头插座【厂家】-温州罗曼电气 | 山东PE给水管厂家,山东双壁波纹管,山东钢带增强波纹管,山东PE穿线管,山东PE农田灌溉管,山东MPP电力保护套管-山东德诺塑业有限公司 | 移动机器人产业联盟官网 | 万师讲师网-优质讲师培训师供应商,讲师认证,找讲师来万师 | 武汉高温老化房,恒温恒湿试验箱,冷热冲击试验箱-武汉安德信检测设备有限公司 | 361°官方网站| 雨燕360体育免费直播_雨燕360免费NBA直播_NBA篮球高清直播无插件-雨燕360体育直播 | 衬氟止回阀_衬氟闸阀_衬氟三通球阀_衬四氟阀门_衬氟阀门厂-浙江利尔多阀门有限公司 | 老城街小面官网_正宗重庆小面加盟技术培训_特色面馆加盟|牛肉拉面|招商加盟代理费用多少钱 | 仪器仪表网 - 永久免费的b2b电子商务平台 | 自动气象站_气象站监测设备_全自动气象站设备_雨量监测站-山东风途物联网 |