php的会话管理

一.cookie

1.如何获取cookie中的值?

示例通过index.php跳转到a.php获得键为name的对应值jason;

index.php代码:

<?php
//设置cookie的键值对
setcookie('name','jason');
setcookie('mm','mark');
//跳转页面
header('Location:a.php');
a.php代码;

<?php
//获取cookie的相应键对应的值
echo $_COOKIE['name'];
在火狐浏览器执行结果:



2.如何通过javascript访问cookie?

示例在index.php中通过弹出框

<?php
//设置cookie的键值对
setcookie('name','jason');
setcookie('mm','mark');
?>
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>cookie知识点</title>
    <script>
        //用js获取cookie
        alert(document.cookie);
    </script>
</head>
<body>
</body>
</html>
显示结果:


3.如果浏览器或用户禁用了cookie,怎么在页面间传递参数?

示例通过URL参数将b.php的值传递到c.php;

b.php代码:

<?php
header('Location:c.php?name=rose');
c.php代码:

<?php
echo $_GET['name'];
通过$_GET可获取对应键的值rose.

二.session:

1.每次重新打开浏览器,服务器将分配给客户端一个新的session_id值。

<?php
//启用session
session_start();
//访问session_id
echo session_id();
2.如果获取session的键对应的值?

示例通过index.php跳转到a.php显示session的相应键对应的值:

index.php代码;

<?php
//启用session
session_start();
//设置session的键值对
$_SESSION['name']='aili';
//跳转页面
header('Location:a.php');
a.php代码:

<?php
//启用session
session_start();
//获取session相应键对应的值
if(isset($_SESSION['name'])){
    echo $_SESSION['name'];
}else{
    echo 'no name found';
}
最后页面跳转成功显示:aili

3.如果要销毁session该如何操作? (ps应用场景:超时后清除登录状态)

  php提供了session_destroy()可以销毁session。

  在index.php中插入session_destroy():

<?php
//启用session
session_start();
//设置session的键值对
$_SESSION['name']='aili';
//销毁session
session_destroy();
//跳转页面
header('Location:a.php');
再执行操作,跳转页面后显示结果为:no name found.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值