>  기사  >  백엔드 개발  >  PHP 세션 추적 1개(41)

PHP 세션 추적 1개(41)

WBOY
WBOY원래의
2016-08-08 09:23:05838검색

PHP 세션 추적

세션 제어란

웹사이트가 클라이언트와 서버 간의 세션을 추적할 수 있도록 강력한 솔루션이 필요합니다. 각 사용자의 신원과 정보를 기억하여 세션 제어를 생성합니다.
??세션 제어란 무엇입니까?
??HTTP는 상태 비저장 프로토콜입니다. 이 프로토콜은 두 트랜잭션 간의 연결을 유지할 수 없습니다.
??사용자가 한 페이지를 요청한 다음 다른 페이지를 요청하는 경우 HTTP는 두 요청이 동일한 사람으로부터 온 것인지 알 수 없습니다.
??세션 제어의 개념은 웹사이트에서 변수를 추적할 수 있다는 것입니다. 변수를 추적함으로써 우리는 사용자를 지원하고 인증 및 사용자 신원을 기반으로 다양한 콘텐츠와 페이지를 표시할 수 있습니다.

세션 추적 기술

숨겨진 양식 필드

세션 추적 필드의 숨겨진 양식 필드를 HTML 페이지에 추가하지만 클라이언트 브라우저에는 표시되지 않습니다

<form action = &ldquo;main.php&rdquo;method=&rdquo;POST&rdquo;><input type = &ldquo;hidden&rdquo;name=&ldquo;checkid&rdquo;value=&ldquo;ZY7K&rdquo;></form><br>在GET 和POST 方法中指定用于存储有关会话消息的名称和值。

URL Rewriting

URL(Uniform Resource Location) 재작성 기술은 URL 끝에 고유한 세션 ID를 추가합니다. 세션을 식별합니다.
??예를 들어 세션 ID=1002

原始URL:http:<span>//</span><span>www.myphp.com/load.php</span>用添加的参数重写的URL:http:<span>//</span><span> www.myphp.com/load.php? id=1002原始URL:</span><span>http://www.myphp.com/bookinfo.php</span>用添加的参数重写的URL:http:<span>//</span><span>www.myphp.com/bookinfo.php?bookid=1000</span>

쿠키와 세션

세션을 추적해야 하는 경우 다음 URL을 다시 작성합니다. 더 넓은 범위, 더 긴 쿠키와 세션을 사용해야 합니다. 예를 들어, 일부 웹사이트에서 콘텐츠를 다운로드하려면 회원이 먼저 로그인해야 합니다. 고객이 로그인했는지, 자동으로 로그인할 수 있는지 알고 싶다면 어떻게 해야 합니까? 쿠키, 세션 등을 통하여 알 수 있습니다.
??예를 들어 온라인 쇼핑 시 장바구니는 고객이 어떤 제품을 선택했는지 어떻게 알 수 있나요? 쿠키와 세션도 기록될 수 있습니다.
간단히 말해서, 쿠키와 세션은 서로 다른 기술이지만 쿠키가 할 수 있는 한 세션도 할 수 있습니다!

쿠키

쿠키란 무엇인가요?
??쿠키는 서버나 스크립트가 http 프로토콜에 따라 클라이언트 정보를 유지하는 방법입니다.
??쿠키는 웹 서버가 이용자의 브라우저에 저장하는 쿠키(작은 텍스트 파일)로, 이용자에 대한 정보를 포함할 수 있으며, 사용자 이름, 비밀번호, 개인 설정, 개인 기본 설정 등을 저장하는 데 자주 사용됩니다. 기록 등 이용자가 서버에 접속하면 서버는 쿠키정보를 설정하고 접근할 수 있습니다.
??쿠키는 클라이언트(일반적으로 IE 또는 Firefox 브라우저)의 쿠키 임시 폴더에 저장되며 수동으로 삭제할 수 있습니다. 참고: 브라우저에 쿠키가 너무 많아 시스템에서 허용하는 범위를 초과하는 경우 브라우저는 해당 쿠키를 자동으로 삭제합니다.

쿠키 작동 원리

고객이 PHP 기술 기반 웹사이트를 방문하면 PHP에서 setcookie() 함수를 사용하여 쿠키를 생성하고 시스템에서 해당 쿠키를 클라이언트로 보냅니다. 처리 후 C:Documents and Settings 사용자 이름 쿠키 디렉토리에 저장됩니다.
??쿠키는 HTTP 헤더의 일부이므로 HTML 자체의 콘텐츠가 브라우저로 전송되기 전에 setcookie() 함수를 호출해야 합니다. 이 제한 사항은 header() 함수와 동일합니다(head() 함수를 이해해야 하는 경우 직접 확인하세요).
??고객이 웹사이트를 다시 방문하면 브라우저는 C:Documents and Settings 사용자 이름 쿠키 디렉터리에 있는 사이트에 해당하는 쿠키를 자동으로 서버에 보내고, 서버는 클라이언트에서 보낸 쿠키를 자동으로 보냅니다. . PHP5에서는 클라이언트가 보낸 쿠키가 전역 변수로 변환됩니다. $_COOKIE['xxx']를 통해 읽을 수 있습니다.

쿠키 정의

쿠키 설정:
?? 구문: boolsetcookie(stringname,[stringvalue,[inexpire,[stringpath,[stringdomain,[intsecure]]]]]);
이 쿠키 함수는 6개의 속성을 가질 수 있으며, 일반적으로 사용되는 함수에는 3개의 매개변수가 있습니다.
??예:
$value="가장 좋은 방법은 스스로 하는 것입니다.";
setcookie("cookiename",$value,time()+60*60*24*7);

setcookie 매개변수 설명

쿠키 수신 및 처리
PHP는 쿠키를 잘 지원합니다. 양식 양식과 마찬가지로 PHP는 웹 서버에서 쿠키를 수신하면 자동으로 시작됩니다. HTTP 헤더를 분석하고 분석합니다. 수신 시 $_COOKIE["cookiename"] 또는 $HTTP_COOKIE_VARS["cookiename"]을 사용하십시오(권장하지 않음)

참고:
웹사이트에 여러 개의 파일 디렉토리가 있는 경우, 경로에 따라 쿠키를 설정한 파일의 경로에서만 쿠키에 접근할 수 있습니다. 경로를 지정하면 설정 시 해당 경로가 쿠키에 접근하기 위한 지정된 경로로 사용됩니다.

쿠키 배열 만들기:

하나:
setcookie("CookieArray[0]", "Value 1");
setcookie("CookieArray[1]", " Value 2");
두 번째:
setcookie("CookieArray['one']", "값 1");
setcookie("CookieArray['two']", "값 2") ;

setcookie()에서 배열 사용

<?<span>php
setcookie(</span><span>"</span><span>cookie[three]</span><span>"</span>, <span>"</span><span>cookiethree</span><span>"</span><span>);
setcookie(</span><span>"</span><span>cookie[two]</span><span>"</span>, <span>"</span><span>cookietwo</span><span>"</span><span>);
setcookie(</span><span>"</span><span>cookie[one]</span><span>"</span>, <span>"</span><span>cookieone</span><span>"</span><span>);
</span><span>//</span><span> 刷新页面后,显示出来</span><span>if</span> (isset($_COOKIE[<span>'</span><span>cookie</span><span>'</span><span>])) {
</span><span>foreach</span>($_COOKIE[<span>'</span><span>cookie</span><span>'</span>] <span>as</span> $name =><span> $value){
echo </span><span>"</span><span>$name : $value <br/>\n</span><span>"</span><span>;
}
}
</span>?>

쿠키 삭제

기존 쿠키를 삭제하려면 두 가지 방법이 있습니다.
1. name 매개변수만 사용하여 setcookie를 호출하면 이
name이라는 쿠키가 클라이언트에서 삭제됩니다.
Setcookie; "); //MyCookie 삭제
2. 쿠키 만료 시간을 time() 또는 time()-1로 설정합니다. 참고:
time()이 얼마나 줄어들든 상관없습니다. 만료 시간이 충분하면
이 쿠키는 이 페이지를 탐색한 후 삭제됩니다
(실제로는 유효하지 않습니다).
??예:
setcookie("MyCookie","Value",time()-1);
 //Delete MyCookie.
참고: 쿠키가 삭제되더라도 해당 값은 현재 페이지에서 여전히
유효합니다. 브라우저가 닫힌 후 쿠키가 만료되도록 설정하려는 경우.
그런 다음 만료 시간을 0으로 직접 설정하거나 이 값을 설정하지 않을 수 있습니다.
예: setcookie("이름","값",0).

쿠키 참고 사항

1. setcookie() 앞에는 html 출력이 있을 수 없습니다. 즉, 공백
줄은 작동하지 않습니다. 2. setcookie() 이후 현재 페이지에서 echo $_COOKIE["name"]을 호출하면 출력이 없습니다. 쿠키 값을 보려면 새로 고치거나 다음 페이지로 이동해야 합니다.
•3. 브라우저가 쿠키를 다르게 처리할 필요가 없습니다. 클라이언트는 쿠키를 비활성화할 수 있으며 브라우저도 쿠키 수를 제한합니다. 브라우저에서 생성할 수 있는 최대 쿠키 수는 300개이며, 각 쿠키는 4KB를 초과할 수 없습니다. 각 웹 사이트에서 설정할 수 있는 총 쿠키 수는 20개를 초과할 수 없습니다.
??4. 쿠키는 클라이언트 측에 저장됩니다. 사용자가 쿠키를 비활성화하면 쿠키는 당연히 아무런 영향을 미치지 않습니다. 따라서 쿠키에 대한 과도한 의존을 피하고 만약의 경우를 대비해 쿠키가 비활성화된 경우 해결책을 생각해 보세요

위의 내용을 포함하여 PHP 세션 추적 원(41)을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.