ホームページ バックエンド開発 PHPチュートリアル php cookie使用方法学习笔记分享!!!

php cookie使用方法学习笔记分享!!!

May 17, 2016 am 08:53 AM
cookie php

在php中cookie与其它程序中没什么两样,cookie都是用来存储信息到客户端,常用用于安全性要求不高的一些应用中,如用户登录记住密码之类的,下面我来给大家介绍一下php cookie学习笔记!!!

php cookie使用方法学习笔记分享!!!

PHP setcookie() 函数向客户端发送一个 HTTP cookie。cookie 是由服务器发送到浏览器的变量。cookie 通常是服务器嵌入到用户计算机中的小文本文件。每当计算机通过浏览器请求一个页面,就会发送这个 cookie。cookie 的名称指定为相同名称的变量。例如,如果被发送的 cookie 名为 "name",会自动创建名为 $user 的变量,包含 cookie 的值。

必须在任何其他输出发送前对 cookie 进行赋值。如果成功,则该函数返回 true,否则返回 false。

  • 1 setcookie(name, value, expire, path, domain, secure)
    •name 必需。规定 cookie 的名称。
    •value 必需。规定 cookie 的值。
    •expire 可选。规定 cookie 的有效期。
    •path 可选。规定 cookie 的服务器路径。
    •domain 可选。规定 cookie 的域名。
    •secure 可选。规定是否通过安全的 HTTPS 连接来传输 cookie。
    可以通过 $HTTP_COOKIE_VARS["user"] 或 $_COOKIE["user"] 来访问名为 "user" 的 cookie 的值。在发送 cookie 时,cookie 的值会自动进行 URL 编码。接收时会进行 URL 解码。如果你不需要这样,可以使用 setrawcookie() 代替。

例,php设置和获取cookie

代码如下:

setcookie('mycookie','value');
//函数原型:int setcookie(string name,string value,int expire,string path,string domain,int secure)echo($mycookie);echo($HTTP_COOKIE_VARS['mycookie']);echo($_COOKIE['mycookie']);
ログイン後にコピー

删除Cookie

(1)调用只带有name参数的setcookie();
(2)使失效时间为time()或time-1;

代码如下:

<?php setcookie(&#39;name&#39;); ?>
setcookie(&#39;mycookie&#39;);或setcookie(&#39;mycookie&#39;,&#39;&#39;);或setcookie("mycookie",false);
//setcookie(&#39;mycookie&#39;,&#39;&#39;,time()-3600);
echo($HTTP_COOKIE_VARS[&#39;mycookie&#39;]);
print_r($_COOKIE);
ログイン後にコピー

建议删除方法:

代码如下:

setcookie(&#39;mycookie&#39;,&#39;&#39;,time()-3600);
ログイン後にコピー

PHP提供一个很好用的函数mktime()。
你只要按顺序传送给mktime()你希望表示的小时,分钟,秒数,月份,日期,及年份,
mktime()就会返回该日期自1970年1月1日的总秒数。
因此,如果需要模拟 Y2K 问题:

代码如下:

$y2k = mktime(0,0,0,1,1,2000);
setcookie(&#39;name&#39;,&#39;value&#39;,$y2k);
setcookie(&#39;name&#39;, &#39;value&#39;, time+3600);
setcookie(&#39;name&#39;, &#39;value&#39;, $y2k, &#39;~/myhome&#39;, &#39;.domain.com&#39;);
ログイン後にコピー

获取COOKIE过期时间的办法

代码如下:

$expire = time() + 86400; // 设置24小时的有效期
setcookie ("var_name", "var_value", $expire); // 设置一个名字为var_name的cookie,并制定了有效期
setcookie ("var_name_expire", $expire, $expire); // 再将过期时间设置进cookie以便你能够知道var_name的过期时间
ログイン後にコピー

注:

在发送 cookie 时,cookie 的值会自动进行 URL 编码。接收时会进行 URL 解码。
如果你不需要这样,可以使用 setrawcookie() 代替。

例,cookie来保存用户登录信息

1、数据库连接配置页面:connectvars.php

代码如下:

<?php
//数据库的位置
define(&#39;DB_HOST&#39;, &#39;localhost&#39;);
//用户名
define(&#39;DB_USER&#39;, &#39;root&#39;);
//口令
define(&#39;DB_PASSWORD&#39;, &#39;19900101&#39;);
//数据库名
define(&#39;DB_NAME&#39;,&#39;test&#39;) ;
?>
ログイン後にコピー

2、登录页面:logIn.php

代码如下:

<?php
//插入连接数据库的相关信息
require_once &#39;connectvars.php&#39;;
$error_msg = "";
//判断用户是否已经设置cookie,如果未设置$_COOKIE[&#39;user_id&#39;]时,执行以下代码
if(!isset($_COOKIE[&#39;user_id&#39;])){
    if(isset($_POST[&#39;submit&#39;])){//判断用户是否提交登录表单,如果是则执行如下代码
        $dbc = mysqli_connect(DB_HOST,DB_USER,DB_PASSWORD,DB_NAME);
        $user_username = mysqli_real_escape_string($dbc,trim($_POST[&#39;username&#39;]));
        $user_password = mysqli_real_escape_string($dbc,trim($_POST[&#39;password&#39;]));
        if(!empty($user_username)&&!empty($user_password)){
            //MySql中的SHA()函数用于对字符串进行单向加密
            $query = "SELECT user_id, username FROM mismatch_user WHERE username = &#39;$user_username&#39; AND "."password = SHA(&#39;$user_password&#39;)";
            //用用户名和密码进行查询
            $data = mysqli_query($dbc,$query);
            //若查到的记录正好为一条,则设置COOKIE,同时进行页面重定向
            if(mysqli_num_rows($data)==1){
                $row = mysqli_fetch_array($data);
                setcookie(&#39;user_id&#39;,$row[&#39;user_id&#39;]);
                setcookie(&#39;username&#39;,$row[&#39;username&#39;]);
                $home_url = &#39;loged.php&#39;;
                header(&#39;Location: &#39;.$home_url);
            }else{//若查到的记录不对,则设置错误信息
                $error_msg = &#39;Sorry, you must enter a valid username and password to log in.&#39;;
            }
        }else{
            $error_msg = &#39;Sorry, you must enter a valid username and password to log in.&#39;;
        }
    }
}else{//如果用户已经登录,则直接跳转到已经登录页面
    $home_url = &#39;loged.php&#39;;
    header(&#39;Location: &#39;.$home_url);
}
?>
<html>
    <head>
        <title>Mismatch - Log In</title>
        <link rel="stylesheet" type="text/css" href="style.css" />
    </head>
    <body>
        <h3>Msimatch - Log In</h3>
        <!--通过$_COOKIE[&#39;user_id&#39;]进行判断,如果用户未登录,则显示登录表单,让用户输入用户名和密码-->
        <?php
        if(empty($_COOKIE[&#39;user_id&#39;])){
            echo &#39;<p class="error">&#39;.$error_msg.&#39;</p>&#39;;
        ?>
        <!-- $_SERVER[&#39;PHP_SELF&#39;]代表用户提交表单时,调用自身php文件 -->
        <form method = "post" action="<?php echo $_SERVER[&#39;PHP_SELF&#39;];?>">
            <fieldset  style="width:250px;">
                <legend>Log In</legend>
                <label for="username">Username:</label>
                <!-- 如果用户已输过用户名,则回显用户名 -->
                <input type="text" id="username" name="username"
                value="<?php if(!empty($user_username)) echo $user_username; ?>" />
                <br/>
                <label for="password">Password:</label>
                <input type="password" id="password" name="password"/>
            </fieldset>   
            <br/>
            <input type="submit" value="Log In" name="submit"/>
        </form>
        <?php
        }
        ?>
    </body>
</html>
ログイン後にコピー

3、登入页面:loged.php

代码如下:

<?php
//已登录页面,显示登录用户名
if(isset($_COOKIE[&#39;username&#39;])){
    echo &#39;You are Logged as &#39;.$_COOKIE[&#39;username&#39;].&#39;<br/>&#39;;
    //点击“Log Out”,则转到logOut.php页面进行cookie的注销
    echo &#39;<a href="logOut.php"> Log Out(&#39;.$_COOKIE[&#39;username&#39;].&#39;)</a>&#39;;
}
/**在已登录页面中,可以利用用户的cookie如$_COOKIE[&#39;username&#39;]、
 * $_COOKIE[&#39;user_id&#39;]对数据库进行查询,可以做好多好多事情*/
?>
ログイン後にコピー

4、注销cookie页面:logOut.php(注销后重定向到lonIn.php)

代码如下:

<?php
/**cookies注销页面*/
if(isset($_COOKIE[&#39;user_id&#39;])){
    //将各个cookie的到期时间设为过去的某个时间,使它们由系统删除,时间以秒为单位
    setcookie(&#39;user_id&#39;,&#39;&#39;,time()-3600);
    setcookie(&#39;username&#39;,&#39;&#39;,time()-3600);
}
//location首部使浏览器重定向到另一个页面
$home_url = &#39;logIn.php&#39;;
header(&#39;Location:&#39;.$home_url);
?>
ログイン後にコピー

最后总结三点,大家必须留意

1: 设置cookie时的注意事项

在同一个页面中设置cookie,实际上是按从后往前的顺序进行的.如果要先删除一个cookie,再写入一个cookie,则必须先写写入语句,再写删除语句.否则会出现错误.

2: setcookie举例

简单的: setcookie("mycookie","value_of_mycookie");
带失效时间的: setcookie("withExpire","Expire_in_1_hour",time()+3600);
什么都有的:setcookie("FullCookie","Full_cookie_value",time+3600,"/forum","www.jb51.net",1);

3: cookie的一些特点

cookie是面向路径的.缺省path属性时,WEB服务器页会自动传递当前路径给浏览器.指定路径会强制服务器使用设置的路径.
在一个目录页面里设的cookie在另一个目录的页面里是看不到的.

推荐学习:《PHP视频教程

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP データベースの操作 CakePHP データベースの操作 Sep 10, 2024 pm 05:25 PM

CakePHP でデータベースを操作するのは非常に簡単です。この章では、CRUD (作成、読み取り、更新、削除) 操作について理解します。

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

See all articles