ホームページ >php教程 >php手册 >PHPセッション変数の詳しい使い方とサンプルコード

PHPセッション変数の詳しい使い方とサンプルコード

WBOY
WBOYオリジナル
2016-06-13 12:47:31892ブラウズ

当您运行一个应用程序时,您会打开它,做些更改,然后关闭它。这很像一次会话。计算机清楚你是谁。它知道你何时启动应用程序,并在何时终止。但是在因特网上,存在一个问题:服务器不知道你是谁以及你做什么,这是由于 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的用法。

(1) セッションの開始
セッションを使用する前に、「session_start();」という文を追加します。名前が示すように、この関数の機能はセッションの使用を開始することです。
(2) セッションの登録
まず、$login などのグローバル配列 (グローバルとして定義する必要があることに注意してください。そうでないと他のページで使用できません) を作成します。 ここで、$login['name'] ="Victor" 、 $login['pwd']="111111" として関数 "session_register(login);" を呼び出すと、セッションは正常に登録されます。
(3) セッションでの変数の使用
セッションの登録と同様に、最初にグローバル配列を作成する必要があり、その後は通常の配列を使用するのと同じです。
(4) セッションが登録されているかどうかを判定
非常に簡単で、「if (session_is_registered(login))」で判定するだけです。
(5) セッションのアンインストール
こちらも非常に簡単で、「session_unregister(login);」するだけです。
注: (2) (3) (4) (5) を行う前に、必ず (1) を行ってください。


以下に例を示します:

index.htm

コードをコピーします コードは次のとおりです。





;title>

= "テキスト" NAME="名前">

パスワード:
<入力タイプ= "送信" 値="送信">




login.php

コードをコピーします

コードは次のとおりです。 global $login

if ($_POST ['name']!="Victor" || $_POST['pwd']!="111111")
{
echo "ログインに失敗しました";
echo "PleaseReturn";
exit;
}
$login = array('name'=>$_POST['name'],
'pwd'= > ;$_POST['pwd']);
session_start();
session_register(login);
echo "情報を表示 >";
echo "ログアウト
";
?>



info.php

コードをコピー

コードは次のとおりです。 session_start(); (session_is_registered(login))

{
global $login;
echo "hello,".$login['name']."
"; a href = logout.php&gt; log out&lt;/a&gt;&lt; br/&gt; ";
}




logout.php




コードをコピー

コードは次のとおりです。

session_start(); (ログイン) ;

header("location:index.htm");

?>

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。