PHP Session 變數的使用方法詳解與執行個體代碼_PHP教程

來源:互聯網
上載者:User
當您運行一個應用程式時,您會開啟它,做些更改,然後關閉它。這很像一次會話。電腦清楚你是誰。它知道你何時啟動應用程式,並在何時終止。但是在網際網路上,存在一個問題:伺服器不知道你是誰以及你做什麼,這是由於 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() 函數必須位於 標籤之前:

複製代碼 代碼如下:







儲存 Session 變數

複製代碼 代碼如下:
session_start();
// store session data
$_SESSION['views']=1;
?>



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



[html]

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

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

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

複製代碼 代碼如下:
session_destroy();
?>

執行個體:

複製代碼 代碼如下:
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;
}
?>

假定本頁名為temp.php


使用者進行登陸post,程式處理寫入session


判斷使用者密碼是否正確


登陸成功的使用者登出登陸


我總結了一下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

複製代碼 代碼如下:


測試





login.php

複製代碼 代碼如下:
global $login;
if ($_POST['name']!="Victor" || $_POST['pwd']!="111111")
{
echo "登陸失敗";
echo "請返回";
exit;
}
$login = array('name'=>$_POST['name'],
'pwd'=>$_POST['pwd']);
session_start();
session_register(login);
echo "查看資訊
";
echo "退出登陸
";
?>

info.php

複製代碼 代碼如下:
session_start();
if (session_is_registered(login))
{
global $login;
echo "hello,".$login['name']."
";
echo "退出登陸
";
}
else
{
echo "非法操作
";
exit;
}
?>


logout.php

複製代碼 代碼如下:
session_start();
session_unregister(login);
header("location:index.htm");
?>

http://www.bkjia.com/PHPjc/313634.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/313634.htmlTechArticle當您運行一個應用程式時,您會開啟它,做些更改,然後關閉它。這很像一次會話。電腦清楚你是誰。它知道你何時啟動應用程式,並在...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.