php session 的應用

PHP Session 變量的使用方法詳解與實例代碼

在php中Session經常用來驗證用戶註冊或登錄之後的驗證了,下面我來總結session變量的一些常用實例與用法介紹

當您運行一個應用程序時,您會打開它,做些更改,然後關閉它。這很像一次會話。計算機清楚你是誰。它知道你何時啓動應用程序,並在何時終止。但是在因特網上,存在一個問題:服務器不知道你是誰以及你做什麼,這是由於 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 變量

複製代碼代碼如下:

<?php
session_start();
// store session data
$_SESSION['views']=1;
?> 
<html>
<body>

<?php
//retrieve session data
echo "Pageviews=". $_SESSION['views'];
?>

</body>
</html>
 [html]

終結 Session
unset() 函數用於釋放指定的 session 變量:

[code]
<?php
unset($_SESSION['views']);
?>
 

您也可以通過 session_destroy() 函數徹底終結 session:

複製代碼代碼如下:

<?php
session_destroy();
?>
 

實例:

複製代碼代碼如下:

<?php 
session_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

複製代碼代碼如下:

<?php 
global $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

複製代碼代碼如下:

<?php 
session_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

複製代碼代碼如下:

<?php 
session_start(); 
session_unregister(login); 
header("location:index.htm"); 
?>
 轉自 http://www.jb51.net/article/41300.htm
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章