PHP Cookie & PHP Session

作者: 廖马儿 | 来源:发表于2017-05-08 15:08 被阅读126次

    作用:常用于识别用户。

    简介:
    cookie常用于识别用户。cookie是服务器留在用户计算机中的小文件。每当相同的计算机通过浏览器请求网页时候,它同事会发送cookie。通过php,可以创建并且取回cookie的值。

    创建cookie:
    setcookie() 函数用于设置cookie
    注释:setcookie()函数必须位于<html>标签之前。
    语法:

    setcookie(name, value, expire, path, domain);
    

    例子:

    <?php 
        setcookie("user", "leo", time()+3600);
    ?>
    <html>
    <body>
    </body>
    </html>
    

    注释:在发送cookie的时候,cookie的值会自动进行URL编码,
    在取回时进行自动解码(为防止URL编码,请使用setrawcookie()取而代之)。

    取回Cookie的值

    PHP的$_COOKIE变量用于取回cookie的值。
    在下面的例子中,我们取回了名为usercookie值,并把它显示在了页面上:

    <?php
         echo $_COOKIE["user"];
        print_r($_COOKIE);
    ?>
    

    在下面的例子中,我们使用isset()函数来确认是否已经设置了cookie:

    <html>
    <body>
    <?php
        if(isset($_COOKIE["user"])) {
            echo "Welcome ".$_COOKIE["user"]."!<br/>";
        }else {
           echo "Welcom guest!<br>";
        }
    ?>
    </body>
    </html>
    

    删除cookie:

    使用过期日期变更为过去的事件点。
    删除的例子:

    <?php
        setcookie("user", "", time()-3600);  // 将过期日期变更为过去的时间点。
    ?>
    

    如果浏览器不支持cookie怎么办?

    如果你的应用程序设计不支持cookie的浏览器,你就不得不采取其他方法在应用程序中从一张页面向另一张页面传递信息。一种方式是从表单传递数据(有关表单和用户输入的内容)。

    <html>
    <body>
        <form action="welcome.php" method="post">
            Name:<input type="text" name="name">
            Age:<input type="text" name="age">
            <input type="submit">
        </form>
    </body>
    </html>
    

    取回"welcom.php"中的值,就像这样:

    <html>
    <body>
        Welcome <?php echo $_POST["name"]; ?>.<br>
        You are <?php echo $_POST["age"]; ?> years old.
    </body>
    </html>
    

    PHP Sessions

    PHP Sessions 变量用于存储有关用户会话的信息,或更改用户会话的设置。
    Session变量保存的信息是单一用户的,并且可供应用程序中的所有页面使用。

    PHP Session变量

    当你运行一个应用程序时,你会打开它,做些更改,然后关闭它。这很像一次会话。计算机清楚你是谁。它知道你合适启动应用程序,并在合适终止。但是在因特网上,存在一个问题:服务器不知道你是谁以及你做什么,这个是由于HTTP地址不能维持状态。

    通过在服务器上存储用户信息以便随后使用,PHP session 解决了这个问题(比如用户名称,购买商品等)。不过,会话信息是临时的,在用户离开网站后将被删除。如果你需要永久存储信息,可以把数据存储在数据库中。

    Session的工作机制是:为每个访问者创建一个唯一的id(UID),并基于这个UID 来存储变量。UID 存储在cookie中,亦或通过URL进行传导。

    开始PHP Session:

    在把用户信息存到PHP Session之前,首先必须启动会话。
    注释:session_start()函数必须位于<html>标签之前:

    <?php session_start(); ?>
    <html>
    <body>
    </body>
    </html>
    

    上面的代码会向服务器注册用户的会话,以便你可以开始保存用户信息,同时会为用户会话分配一个UID。

    存储Session变量

    存储和取回session变量的正确方法是使用PHP $_SESSION变量:

    <?php
        session_start();
        // 存储session 数据
        $_SESSION['views'] = 1;
    ?>
    <html>
    <body>
    <?php  
        // 取回session data
        echo "Pageviews=".$_SESSION['views'];
    ?>
    </body>
    </html>
    

    计数器:

    <?php
    session_start();
    
    if(isset($_SESSION['views']))
      $_SESSION['views']=$_SESSION['views']+1;
    
    else
      $_SESSION['views']=1;
    echo "Views=". $_SESSION['views'];
    ?>
    

    终结Session:

    可以使用unset()或者session_destory()函数。
    unset()函数用于释放指定的session变量

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

    或者:

    <?php
        session_destroy();
    ?>
    

    注释:session_destroy() 将重置session,你将会失去所有session数据。

    相关文章

      网友评论

        本文标题:PHP Cookie & PHP Session

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