美文网首页
使用COOKIE和用户会话

使用COOKIE和用户会话

作者: 12end | 来源:发表于2019-01-15 18:23 被阅读0次

    COOKIE

    COOKIE简介

    由用户浏览器存储的少量数据
    内容包含名字,值,过期时间已经主机和路径信息
    一个单个主机可以请求保存20个cookie,每个cookie大小限制为4kb
    <u>cookie不应该作为基本元素而依赖</u>

    访问COOKIE

    cookie在环境变量 HTTP_COOKIE 中或者作为 $_COOKIE 超全局变量的一部分,通过如下三种方式访问它们

    * echo $_SERVER['HTTP_COOKIE'];
    * echo getenv('HTTP_COOKIE');
    * echo $_COOKIE['vegetable'];
    

    在JavaScript中,可以通过 document.cookie 访问 cookie

    设置COOKIE

    用两种方式在PHP脚本中设置COOIKIE

    • 通过 header() 函数设置Set-Cookie标头
    • 通过 setcookie() 函数设置COOKIE
    <?php
    setcookie("name","jack",time()+3600,"/","xxx.com",0);
    if(isset($_COOKIE['name'])){
    echo "$_COOKIE['name']";
    }
    else
    echo "This is first visit";
    //函数接受cookie名字,cookie值,过期日期,路径,域以及一个整数(安全参数)
    ?>
    

    即使我们在脚本第一次运行的时候设置cookie,$_COOKIE['name'] 变量在这时也不会被创建。由于只有当浏览器将一个cookie发送到服务器的时候才会读取它,因此,直到用户重新访问这个域内的一个页面时,我们才能够读取它
    过期时间以UNIX时间戳为格式(从1970年到当前时间的秒数),time() 函数可以获取当前时间的时间戳

    删除COOKIE

    通过 name 参数调用 setcookie() 可以重新设置所有存储的值
    要绝对确保你的cookie不再有效,或者存储任意的值,也可以使用一个过期的时间戳设置cookie
    setcookie("name","",time()-60,"/","xxx.com",0)
    通过这种方式删除cookie时,确保传递与最初设置时相同的路径,域名和安全参数

    会话

    服务器端会话为用户提供一个唯一的标识符,随后可以用来存储和获取连接到该标识符的信息。任何已经和会话相关联的变量,都通过 $_SESSION 超全局变量变得可供使用。
    要使用一个会话,我们要显式地开始或者继续会话。默认情况下,会话不会自动启动。
    可以在php.ini文件中找到session.auto_start = 0将其改为1使得会话自动启动
    会话启动函数session_start()
    会话启动之后,可以立即通过 session_id() 函数访问用户的会话id

    使用会话变量

    当一个会话启动后,我们可以在超全局变量 _SEDSSION 中存储任意多的变量

    销毁会话和重置变量

    可以用 session_destory() 函数来结束一个会话,消除所有的会话变量。(在当前脚本结束前,会话变量不会被立即销毁)

    session_start();
    $_SESSION['test']=5;
    session_destory();
    echo $_SESSION['test'];         //输出5
    

    要从一个会话中删除所有已注册变量,只需要简单的重置变量:

    session_start();
    $_SESSION['test']=5;
    session_destory();
    unset($_SESSION['test']);
    echo $_SESSION['test'];         //输出空或者报错
    

    相关文章

      网友评论

          本文标题:使用COOKIE和用户会话

          本文链接:https://www.haomeiwen.com/subject/cpzydqtx.html