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 헤더와 마찬가지로 쿠키는 스크립트가 출력을 생성하기 전에 전송되어야 합니다(프로토콜 제한으로 인해). 출력(100db36a723c770d327fc0aef2ce13b1 및 93f0f5c25f18dab9d176bd4f6de5d30e 또는 공백 포함)을 생성하기 전에 이 함수를 호출하세요. 쿠키가 설정되면 다음에 페이지를 열 때 $_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>
쿠키 삭제
쿠키를 삭제하려면 만료 시간을 과거로 설정하여 브라우저의 삭제 메커니즘을 실행해야 합니다.
6cea04fb82bc3707e126c08c4226c5fb
用于记录当前用户访问网站的次数:
<?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['username']; $upwd=$_POST['pwd']; //验证用户名和密码 if($uid=="admin" && $upwd=="pass") { echo("您已经登入成功,欢迎光临"); if($_POST['checkboxCookie']=="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 중국어 웹사이트의 기타 관련 기사를 참조하세요!