在php中Session經常用來驗證用戶注冊或登錄之后的驗證了,下面我來總結session變量的一些常用實例與用法介紹
當您運行一個html' target='_blank'>應用程序時,您會打開它,做些更改,然后關閉它。這很像一次會話。計算機清楚你是誰。它知道你何時啟動應用程序,并在何時終止。但是在因特網上,存在一個問題:服務器不知道你是誰以及你做什么,這是由于 HTTP 地址不能維持狀態。
通過在服務器上存儲用戶信息以便隨后使用,PHP session 解決了這個問題(比如用戶名稱、購買商品等)。不過,會話信息是臨時的,在用戶離開網站后將被刪除。如果您需要永久儲存信息,可以把數據存儲在數據庫中。
把手冊抄一下,然后每個都試試然后寫出來,方便自己查閱滴,誰讓咱剛學呢。
Session大概有12個函數分別是:
session_start: 初始 session。
session_destroy: 結束 session。
session_unset: 釋放session內存。
session_name: 存取目前 session 名稱。
session_module_name: 存取目前 session 模塊。
session_save_path: 存取目前 session 路徑。
session_id: 存取目前 session 代號。
session_register: 注冊新的變量。
session_unregister: 刪除已注冊變量。
session_is_registered: 檢查變量是否注冊。
session_decode: Session 資料解碼。
session_encode: Session 資料編碼。
還有個全局變量就是:$_SESSION
在您把用戶信息存儲到 PHP session 中之前,首先必須啟動會話。
注釋:session_start() 函數必須位于標簽之前:
代碼如下:
<?php session_start(); ?><html><body></body></html>
存儲 Session 變量
代碼如下:
<?phpsession_start();// store session data$_SESSION['views']=1;?><html><body><?php//retrieve session dataecho "Pageviews=". $_SESSION['views'];?></body></html>
終結 Session
unset() 函數用于釋放指定的 session 變量:
<?phpunset($_SESSION['views']);?>
您也可以通過 session_destroy() 函數徹底終結 session:
代碼如下:
<?phpsession_destroy();?>
實例
代碼如下:
<?phpsession_start();switch ( $_GET['action'] ){case "loginif";//登陸驗證,假定session儲存的秘密應該等于123才為正確if ($_SESSION['pass']=="123"){echo "密碼正確 您可以執行注銷";}else{echo "密碼錯誤,您可以重新登陸";}break;case "logout";//注銷登陸session_unset();session_destroy();echo "注銷成功!可以判斷一下密碼是否正確來看看是不是成功注銷";break;case "login";//寫入session以供驗證,$pass="123";//密碼$_SESSION['pass']=$pass;echo "寫入登陸密碼了 去判斷密碼成功與否吧。";break;}?><p>假定本頁名為temp.php </p><p><a href="temp.php?action=login">用戶進行登陸post,程序處理寫入session</a></p><p><a href="temp.php?action=loginif">判斷用戶密碼是否正確</a></p><p><a href="temp.php?action=logout">登陸成功的用戶注銷登陸</a></p>
我總結了一下php中session的用法。
(一)開始session
在每一次使用session之前,都要加上這一句:“session_start();”。顧名思義,這個函數的作用就是開始使用session。
(二)注冊session
首先要建立一個global(注意,一定要定義為global,不然在其它頁面用不了)數組,如$login,其中$login['name']="Victor",$login['pwd']="111111",然后調用函數“session_register(login);”,session就成功注冊了。
(三)使用session里面的變量
和注冊session類似,都要先建立一個global數組,然后就和使用一般數組一樣了。
(四)判斷session是否注冊
很簡單,用“if (session_is_registered(login))”判斷就可以了。
(五)卸載session
也很簡單,“session_unregister(login);”就可以了。
注意:在進行(二)(三)(四)(五)之前一定要先進行(一)。
下面給出一個例子:
index.htm
<html><head><title>測試</title></head><body><FORM METHOD=POST ACTION="login.php">用戶名:<INPUT TYPE="text" NAME="name"><br/>密碼:<INPUT TYPE="password" name="pwd"><br/><INPUT TYPE="submit" value="提交"></FORM></body></html>
login.php
代碼如下:
<?phpglobal $login;if ($_POST['name']!="Victor" || $_POST['pwd']!="111111"){echo "登陸失敗";echo "請<a href=index.htm>返回</a>";exit;}$login = array('name'=>$_POST['name'],'pwd'=>$_POST['pwd']);session_start();session_register(login);echo "<a href=info.php>查看信息</a><br/>";echo "<a href=logout.php>退出登陸</a><br/>";?>
info.php
代碼如下:
<?phpsession_start();if (session_is_registered(login)){global $login;echo "hello,".$login['name']."<br/>";echo "<a href=logout.php>退出登陸</a><br/>";}else{echo "非法操作<br/>";exit;}?>
logout.php
代碼如下:
<?phpsession_start();session_unregister(login);header("location:index.htm");?>PHP編程
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答