• <sup id="mk476"></sup>
    <dl id="mk476"></dl>
  • <progress id="mk476"><tr id="mk476"></tr></progress>
    <div id="mk476"><tr id="mk476"></tr></div>
    <sup id="mk476"><ins id="mk476"></ins></sup>
  • <progress id="mk476"></progress>
    <div id="mk476"></div>
    <div id="mk476"><tr id="mk476"></tr></div>
  • <div id="mk476"></div>
    <dl id="mk476"><s id="mk476"></s></dl><dl id="mk476"></dl><div id="mk476"></div>
  • <div id="mk476"></div>
    <dl id="mk476"><ins id="mk476"></ins></dl>

    【PHP基礎】cookies和session

    1.Cookies

    cookie 常用于識別用戶。cookie 是服務器留在用戶計算機中的小文件。每當相同的計算機通過瀏覽器請求頁面時,它同時會發送 cookie。通過 PHP,您能夠創建并取回 cookie 的值。

    1.1、如何創建 cookie?

    setcookie() 函數用于設置 cookie。

    注釋:setcookie() 函數必須位于 <html> 標簽之前。

    語法:setcookie(name, value, expire, path, domain);

    在下面的例子中,我們將創建名為 "user" 的 cookie,把為它賦值 "Alex Porter"。我們也規定了此 cookie 在一小時后過期:

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

    注釋:在發送 cookie 時,cookie 的值會自動進行 URL 編碼,在取回時進行自動解碼(為防止 URL 編碼,請使用 setrawcookie() )。

    1.2、如何取回 Cookie 的值?

    PHP 的 $_COOKIE 變量用于取回 cookie 的值。

    在下面的例子中,我們取回了名為 "user" 的 cookie 的值,并把它顯示在了頁面上:

    <?php
    // Print a cookie
    echo $_COOKIE["user"];
    
    // A way to view all cookies
    print_r($_COOKIE);
    ?>

    在下面的例子中,我們使用 isset() 函數來確認是否已設置了 cookie:

    <html>
    <body>
    
    <?php
    if (isset($_COOKIE["user"]))        //  isset()函數檢查變量是否被設置
      echo "Welcome " . $_COOKIE["user"] . "!<br />";
    else
      echo "Welcome guest!<br />";
    ?>
    
    </body>
    </html> 

    1.3、如何刪除 cookie?

    當刪除 cookie 時,您應當使過期日期變更為過去的時間點。

    刪除的例子:

    <?php 
    // set the expiration date to one hour ago
    setcookie("user", "", time()-3600);
    ?> 

    如果瀏覽器不支持 cookie 該怎么辦?

    如果您的應用程序涉及不支持 cookie 的瀏覽器,您就不得不采取其他方法在應用程序中從一張頁面向另一張頁面傳遞信息。一種方式是從表單傳遞數據(有關表單和用戶輸入的內容,稍早前我們已經在本教程中介紹過了)。

    下面的表單在用戶單擊提交按鈕時向 "welcome.php" 提交了用戶輸入:

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

    取回 "welcome.php" 中的值,就像這樣:

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

     

    2.Sessions

    PHP session 變量用于存儲有關用戶會話的信息,或更改用戶會話的設置。Session 變量保存的信息是單一用戶的,并且可供應用程序中的所有頁面使用。

    當您運行一個應用程序時,您會打開它,做些更改,然后關閉它。這很像一次會話。計算機清楚你是誰。它知道你何時啟動應用程序,并在何時終止。但是在因特網上,存在一個問題:服務器不知道你是誰以及你做什么,這是由于 HTTP 地址不能維持狀態。

    通過在服務器上存儲用戶信息以便隨后使用,PHP session 解決了這個問題(比如用戶名稱、購買商品等)。不過,會話信息是臨時的,在用戶離開網站后將被刪除。如果您需要永久儲存信息,可以把數據存儲在數據庫中。

    Session 的工作機制是:為每個訪問者創建一個唯一的 id (UID),并基于這個 UID 來存儲變量。UID 存儲在 cookie 中,亦或通過 URL 進行傳導。

    2.1、開始 Session

    在您把用戶信息存儲到 PHP session 中之前,首先必須啟動會話。

    注釋:session_start() 函數必須位于 <html> 標簽之前:

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

    上面的代碼會向服務器注冊用戶的會話,以便您可以開始保存用戶信息,同時會為用戶會話分配一個 UID。

     2.2、存儲 Session 變量

    存儲和取回 session 變量的正確方法是使用 PHP $_SESSION 變量:

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

    輸出:

    Pageviews=1

    在下面的例子中,我們創建了一個簡單的 page-view 計數器。isset() 函數檢測是否已設置 "views" 變量。如果已設置 "views" 變量,我們累加計數器。如果 "views" 不存在,則我們創建 "views" 變量,并把它設置為 1:

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

    2.3、終結 Session

    如果您希望刪除某些 session 數據,可以使用  unset()  或者 session_destroy() 函數。

    ------先unset()后session_destroy()退出登錄更徹底------

    unset() 函數用于釋放指定的 session 變量:

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

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

    <?php
    session_destroy();
    ?>

     

    注釋:session_destroy() 將重置 session,您將失去所有已存儲的 session 數據。

    ---------------------------------------------------------------------------------------------------------------------------------------------------

    cookie和session的聯系與區別

    聯系:

    1.Cookie和Session有很多相似的地方,都是用來臨時存儲用戶狀態和相關信息。有很多情況下,使用兩者都可以實現某些特定功能。用戶敏感信息保存在cookie或者在session都可以,兩個各有特點。

    2.通常情況下Session的sid保存在cookie中。客戶端與服務器交互時客戶端cookie發送sid到服務器達到身份認證目的,session是基于cookie但又不完全依賴cookie(其次是“url重寫”方案,sid寫在url中一起發送到服務端,比如很多手機瀏覽器即使如此)。

    區別:

    Cookie(儲存在用戶本地終端上的數據):

    1.保存在客戶端,其值在客戶端與服務端之間傳送。客戶端保持狀態的方案。

    2.不安全,存儲的數據量有限。

    3.Cookie可以長期有效。

    Session特征(會話):

    1.保存在服務端,每一個session在服務端有一個sessionID作一個標識(客戶端發送不同SID識別不同用戶)。服務器端保持狀態的方案。

    2.存儲的數據量大,安全性高。占用服務端的內存資源。

    3.Session的生存期在會話結束后即結束。下次新創建的sid即不重復也沒有規律。

    posted @ 2018-09-22 17:35 樂觀向上的cody 閱讀(...) 評論(...) 編輯 收藏
    江苏11选5软件