欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2013年09月11日 11:07:47   作者:  
在php中Session經(jīng)常用來驗(yàn)證用戶注冊(cè)或登錄之后的驗(yàn)證了,下面我來總結(jié)session變量的一些常用實(shí)例與用法介紹

當(dāng)您運(yùn)行一個(gè)應(yīng)用程序時(shí),您會(huì)打開它,做些更改,然后關(guān)閉它。這很像一次會(huì)話。計(jì)算機(jī)清楚你是誰。它知道你何時(shí)啟動(dòng)應(yīng)用程序,并在何時(shí)終止。但是在因特網(wǎng)上,存在一個(gè)問題:服務(wù)器不知道你是誰以及你做什么,這是由于 HTTP 地址不能維持狀態(tài)。
通過在服務(wù)器上存儲(chǔ)用戶信息以便隨后使用,PHP session 解決了這個(gè)問題(比如用戶名稱、購買商品等)。不過,會(huì)話信息是臨時(shí)的,在用戶離開網(wǎng)站后將被刪除。如果您需要永久儲(chǔ)存信息,可以把數(shù)據(jù)存儲(chǔ)在數(shù)據(jù)庫中。

把手冊(cè)抄一下,然后每個(gè)都試試然后寫出來,方便自己查閱滴,誰讓咱剛學(xué)呢。Session大概有12個(gè)函數(shù)分別是:

session_start: 初始 session。
session_destroy: 結(jié)束 session。
session_unset: 釋放session內(nèi)存。
session_name: 存取目前 session 名稱。
session_module_name: 存取目前 session 模塊。
session_save_path: 存取目前 session 路徑。
session_id: 存取目前 session 代號(hào)。
session_register: 注冊(cè)新的變量。
session_unregister: 刪除已注冊(cè)變量。
session_is_registered: 檢查變量是否注冊(cè)。
session_decode: Session 資料解碼。
session_encode: Session 資料編碼。

還有個(gè)全局變量就是:$_SESSION


在您把用戶信息存儲(chǔ)到 PHP session 中之前,首先必須啟動(dòng)會(huì)話。
注釋:session_start() 函數(shù)必須位于 標(biāo)簽之前:

復(fù)制代碼 代碼如下:

<?php session_start(); ?>

<html>
<body>

</body>
</html>
 

存儲(chǔ) Session 變量

復(fù)制代碼 代碼如下:

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

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

</body>
</html>
 [html]

終結(jié) Session
unset() 函數(shù)用于釋放指定的 session 變量:

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

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

復(fù)制代碼 代碼如下:

<?php
session_destroy();
?>
 

實(shí)例:

復(fù)制代碼 代碼如下:

<?php
session_start();
switch ( $_GET['action'] ){
case "loginif";
//登陸驗(yàn)證,假定session儲(chǔ)存的秘密應(yīng)該等于123才為正確
if ($_SESSION['pass']=="123"){echo "密碼正確 您可以執(zhí)行注銷";}else{echo "密碼錯(cuò)誤,您可以重新登陸";}
break;
case "logout";
//注銷登陸
session_unset();
session_destroy();
echo "注銷成功!可以判斷一下密碼是否正確來看看是不是成功注銷";
break;
case "login";
//寫入session以供驗(yàn)證,
$pass="123";//密碼
$_SESSION['pass']=$pass;
echo "寫入登陸密碼了 去判斷密碼成功與否吧。";
break;
}
?>
<p>假定本頁名為temp.php </p>
<p><a href="temp.php?action=login">用戶進(jìn)行登陸post,程序處理寫入session</a></p>
<p><a href="temp.php?action=loginif">判斷用戶密碼是否正確</a></p>
<p><a href="temp.php?action=logout">登陸成功的用戶注銷登陸</a></p>
 

我總結(jié)了一下php中session的用法。

(一)開始session
  在每一次使用session之前,都要加上這一句:“session_start();”。顧名思義,這個(gè)函數(shù)的作用就是開始使用session。
(二)注冊(cè)session
  首先要建立一個(gè)global(注意,一定要定義為global,不然在其它頁面用不了)數(shù)組,如$login,其中$login['name']="Victor",$login['pwd']="111111",然后調(diào)用函數(shù)“session_register(login);”,session就成功注冊(cè)了。
(三)使用session里面的變量
  和注冊(cè)session類似,都要先建立一個(gè)global數(shù)組,然后就和使用一般數(shù)組一樣了。
(四)判斷session是否注冊(cè)
  很簡單,用“if (session_is_registered(login))”判斷就可以了。
(五)卸載session
  也很簡單,“session_unregister(login);”就可以了。
  注意:在進(jìn)行(二)(三)(四)(五)之前一定要先進(jìn)行(一)。


下面給出一個(gè)例子:

index.htm

復(fù)制代碼 代碼如下:

<html>
<head>
<title>測(cè)試</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

復(fù)制代碼 代碼如下:

<?php
global $login;
if ($_POST['name']!="Victor" || $_POST['pwd']!="111111")
{
        echo "登陸失敗";
        echo "請(qǐng)<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

復(fù)制代碼 代碼如下:

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

復(fù)制代碼 代碼如下:

<?php
session_start();
session_unregister(login);
header("location:index.htm");
?>
 

相關(guān)文章

最新評(píng)論