PHP 세션 제어를 위한 쿠키에 대한 자세한 설명

小云云
풀어 주다: 2023-03-22 10:40:02
원래의
1902명이 탐색했습니다.

1. 쿠키란 무엇입니까?

복수형 쿠키로도 사용되는 경우가 있습니다. 쿠키는 사용자의 신원을 식별하고 세션 추적을 수행하기 위해 일부 웹사이트에서 사용자의 로컬 터미널에 저장한 데이터(일반적으로 암호화됨)를 의미합니다. . 쿠키의 가장 일반적인 적용은 등록된 사용자가 웹사이트에 로그인했는지 여부를 확인하는 것입니다. 사용자는 로그인 절차를 단순화하기 위해 다음번에 웹사이트에 접속할 때 사용자 정보를 유지할지 여부를 묻는 메시지를 받을 수 있습니다. 또 다른 중요한 응용 분야는 "장바구니" 처리입니다. 사용자는 일정 기간 내에 동일한 웹사이트의 다른 페이지에서 다른 제품을 선택할 수 있으며, 이 정보는 쿠키에 기록되어 최종 결제 시 해당 정보를 검색할 수 있습니다.

장점:

좋은 호환성

단점:

1. 네트워크 트래픽 증가

2. 데이터 용량은 제한되어 있으며 클라이언트는 브라우저에 따라 데이터를 비활성화하거나 삭제할 수 있습니다. 쿠키로 인해 프로그램 기능에 영향을 미칩니다.

3.안전하지 않습니다. 여러 사람이 컴퓨터를 공유하는 경우 쿠키를 사용하면 사용자의 개인 정보가 유출되고 보안 문제가 발생할 수 있습니다.

2. 쿠키 작동 방식:

쿠키는 일부 "키-값" 쌍을 저장하는 웹 서버에 의해 사용자의 하드 드라이브에 저장되는 텍스트 조각입니다. 각 웹 사이트는 사용자 컴퓨터에 쿠키를 저장하고 필요할 때 쿠키 데이터를 검색할 수 있습니다. 일반적으로 웹사이트에는 쿠키 파일이 있습니다. 사용자는 사이트 A를 방문할 때마다 사이트 A의 쿠키 파일을 검색합니다. 쿠키 파일이 존재하는 경우 해당 파일에서 사용자 이름과 비밀번호 "키-값" 쌍 데이터를 읽습니다. 사용자 이름과 비밀번호 "키-값" 쌍 데이터가 발견되면 액세스 요청과 함께 사이트 A로 전송됩니다. 사이트 A가 액세스 요청을 받을 때 사용자 이름과 비밀번호 "키-값" 데이터도 수신한 경우 사용자 이름과 비밀번호 데이터를 사용하여 로그인하므로 사용자는 사용자 이름과 비밀번호를 입력할 필요가 없습니다. 사용자 이름과 비밀번호 "키-값" 쌍 데이터가 수신되지 않으면 이는 사용자가 이전에 성공적으로 로그인하지 못했음을 의미합니다. 이때 사이트 A는 사용자에게 로그인 페이지를 반환합니다. 또한 각 쿠키에는 만료일이 있으며, 만료된 쿠키는 더 이상 사용할 수 없습니다. 일반적으로 사용되는 쿠키 작업에는 쿠키 데이터 설정, 쿠키 데이터 읽기 및 지정된 쿠키 데이터 삭제가 있습니다.

구문:

bool setcookie ( string $name [, string $value = "" [, int $expire = 0 [, string $path = "" [, string $domain = "" [, bool $secure = false [, bool $httponly = false ]]]]]] )

setcookie()는 나머지 HTTP 헤더와 함께 클라이언트에 전송될 쿠키를 정의합니다. 다른 HTTP 헤더와 마찬가지로 쿠키는 스크립트가 출력을 생성하기 전에 전송되어야 합니다(프로토콜 제한으로 인해). 출력( 및 또는 공백 포함)을 생성하기 전에 이 함수를 호출하세요. 쿠키가 설정되면 다음에 페이지를 열 때 $_COOKIE를 사용하여 읽을 수 있습니다. 쿠키 값은 $_REQUEST

name: 쿠키 이름에도 존재합니다.

값: 쿠키 값입니다. 이 값은 사용자의 컴퓨터에 저장됩니다. 민감한 정보는 저장하지 마세요. 예를 들어 name은 'cookiename'이고, 그 값은 $_COOKIE['cookiename']을 통해 얻을 수 있습니다.

expire: 쿠키 만료 시간입니다. 이것은 Unix 시대(1970년 1월 1일 00:00:00 GMT) 이후의 초 수인 Unix 타임스탬프입니다. 즉, 기본적으로 time() 함수의 결과와 만료하려는 초 수를 사용할 수 있습니다. 아니면 mktime()을 사용할 수도 있습니다. time()+60*60*24*30은 쿠키가 30일 후에 만료되도록 설정하는 것입니다. 0으로 설정되거나 매개변수가 생략되면 쿠키는 세션이 끝날 때(예: 브라우저가 닫힐 때) 만료됩니다.

경로: 쿠키의 유효한 서버 경로입니다. '/'로 설정하면 해당 쿠키는 전체 도메인 이름 도메인에 대해 유효합니다. '/foo/'로 설정된 경우 쿠키는 /foo/ 디렉터리와 도메인의 해당 하위 디렉터리(예: /foo/bar/)에만 유효합니다. 기본값은 쿠키가 설정될 때의 현재 디렉터리입니다.

domain: 쿠키의 유효한 도메인/하위 도메인 이름입니다. 이를 하위 도메인(예: 'www.example.com')으로 설정하면 이 하위 도메인과 세 번째 수준 도메인(예: w2.www.example.com)에 대해 쿠키가 유효해집니다. 전체 도메인(모든 하위 도메인 포함)에 대해 쿠키를 유효하게 만들려면 해당 쿠키를 도메인 이름(이 경우 'example.com')으로 설정하면 됩니다.

secure: 이 쿠키가 보안 HTTPS 연결을 통해서만 클라이언트에 전달되는지 여부를 설정합니다. TRUE로 설정하면 보안 연결이 존재하는 경우에만 쿠키가 설정됩니다. 이 요구 사항이 서버 측에서 처리되는 경우 프로그래머는 보안 연결($_SERVER["HTTPS"]에 의해 결정됨)을 통해서만 해당 쿠키를 보내면 됩니다.

httponly: TRUE로 설정하면 HTTP 프로토콜을 통해서만 쿠키에 액세스할 수 있습니다. 이는 JavaScript와 같은 스크립트 언어를 통해 쿠키에 접근할 수 없음을 의미합니다. 거짓, 제한이 없습니다.

반환 값

이 함수를 호출하기 전에 출력이 생성되면 setcookie()는 실패하고 FALSE를 반환합니다. setcookie()가 성공적으로 실행되면 TRUE를 반환합니다. 물론, 이용자가 쿠키를 허용했는지 여부를 의미하는 것은 아닙니다.

쿠키 설정 및 읽기

<?php
    $value="my cookie value"; //发送一个简单的cookie
    setcookie("testcookie",$value,time()+60);  //set cookie?><!DOCTYPE html><html><head>
    <meta charset="UTF-8">
    <title>Testcookie</title></head><body>
    <?php 
        if(isset($_COOKIE["testcookie"])) //判断是否存在
            echo($_COOKIE["testcookie"]."<br>");
        print_r($_COOKIE);    ?></body></html>
로그인 후 복사

쿠키 삭제

쿠키를 삭제하려면 만료 시간을 과거로 설정하여 브라우저의 삭제 메커니즘을 실행해야 합니다.

?>

用于记录当前用户访问网站的次数:

<?php

   if(isset($_COOKIE["num"]))        $num=$_COOKIE["num"];    else
       $num=0;                        //首次设置cookie

       $num=$num+1;                 
   setcookie("num",$num,time()+60*60) //发送一个cookie num记录访问次数?><!DOCTYPE html><html><head>
   <meta charset="UTF-8">
   <title>Testcookie</title></head><body>
   <?php 
       if($num>1)            echo("您已经第".$num."次访问本站点了。");        else
           echo("欢迎首次访问本站");        //关闭网页后,变量$num将被释放,但因为它的值已经保存再cookie中,所以下次打开网页会连续计数
   ?></body></html>
로그인 후 복사

用户验证身份是验证cookie:

<?php  //身份验证cookie
   header("content-type:text/html;charset=utf-8");
   error_reporting(0);    //取输入的用户名和密码
       $uid=$_POST[&#39;username&#39;];        $upwd=$_POST[&#39;pwd&#39;];    //验证用户名和密码
   if($uid=="admin" && $upwd=="pass")
   {        echo("您已经登入成功,欢迎光临");        if($_POST[&#39;checkboxCookie&#39;]=="on")
       {
           setcookie("username",$uid,time()+60*60*24);
           setcookie("pwd",$upwd,time()+60*60*24);
       }
   }   
   else
       echo("登入失败,请返回重新登录");?><?php
   error_reporting(0);?><!DOCTYPE html><html><head>
   <meta charset="UTF-8">
   <title>Testcookie</title>
   <style type="text/css">form {    margin-top: 300px;    padding-left: 40%;}input[type="password"]{    margin-left: 16px;}input[type="reset"],input[type="submit"]{    margin-left: 80px;}</style></head><body>

   <form action="1.php" method="POST">

   <label>用户名:        <input type="text" name="uesrname" value=" <?php echo($_COOKIE["username"]);?>">    </label>
   <br><br>
                                                       <!-- 保留上次成功登入的用户名-->
   <lable>密码:    <input type="password" name="pwd" value="<?php echo($_COOKIE["password"]);?>" >    </lable>
                                                       <!-- 保留上次成功登入的用户名 -->
   <input type="checkbox" checked name="checkboxCookie">保留用户信息<br><br> <!-- 复选框 -->
   <input type="submit" name="put_info" value="登录">
   <input type="reset" name="rest_info" value="重置">
   </form></body></html>
로그인 후 복사

相关推荐:

如何理解PHP中的会话控制

php中会话控制的深入理解

详细介绍php会话控制的实例代码

위 내용은 PHP 세션 제어를 위한 쿠키에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!