php Session 變數的使用方法詳解

怪我咯
發布: 2023-03-13 09:42:01
原創
1434 人瀏覽過

在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[&#39;views&#39;]=1;
?> 
<html>
<body>

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

</body>
</html>
 [html]
终结 Session
unset() 函数用于释放指定的 session 变量:
[code]
<?php
unset($_SESSION[&#39;views&#39;]);
?>
登入後複製

您也可以透過session_destroy() 函數徹底結束session:

 程式碼如下:

<?php
session_destroy();
?>
登入後複製

實例:

程式碼如下:

?> 
<p>假定本页名为temp.php </p> 
<p><a href="temp.php?action=login">用户进行登陆post,<?php 
session_start(); 
switch ( $_GET[&#39;action&#39;] ){ 
case "loginif"; 
//登陆验证,假定session储存的秘密应该等于123才为正确 
if ($_SESSION[&#39;pass&#39;]=="123"){echo "密码正确 您可以执行注销";}else{echo "密码错误,您可以重新登陆";} 
break; 
case "logout"; 
//注销登陆 
session_unset(); 
session_destroy(); 
echo "注销成功!可以判断一下密码是否正确来看看是不是成功注销"; 
break; 
case "login"; 
//写入session以供验证, 
$pass="123";//密码 
$_SESSION[&#39;pass&#39;]=$pass; 
echo "写入登陆密码了 去判断密码成功与否吧。"; 
break; 
} 程序处理写入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[&#39;name&#39;]!="Victor" || $_POST[&#39;pwd&#39;]!="111111") 
{ 
        echo "登陆失败"; 
        echo "请<a href=index.htm>返回</a>"; 
        exit; 
} 
$login = array(&#39;name&#39;=>$_POST[&#39;name&#39;], 
                           &#39;pwd&#39;=>$_POST[&#39;pwd&#39;]); 
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[&#39;name&#39;]."<br/>"; 
        echo "<a href=logout.php>退出登陆</a><br/>"; 
} 
else 
{ 
        echo "非法操作<br/>"; 
        exit; 
} 
?>
登入後複製

logout.php

程式碼如下:

<?php 
session_start(); 
session_unregister(login); 
header("location:index.htm"); 
?>
登入後複製

以上是php Session 變數的使用方法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!