PHP는 http 프로토콜의 헤더 정보에 쿠키를 보내기 때문에 브라우저에 다른 정보를 출력하기 전에 setcookie() 함수를 호출해야 하는데, 이는 header() 함수의 제한과 유사합니다.
1. 쿠키 설정:
a.
예:
PHP 코드
b.
예:
PHP 코드
---------------------------- ----------------- --------------------------------- ----------------- ---------------------------------
PHP 내장 슈퍼 전역 변수 $_COOKIE를 직접 사용하여 브라우저 측에서 쿠키를 읽습니다.
예:
PHP 코드
3.
그냥 유효한 시간을 현재 시간보다 작게 설정하고 값을 null로 설정합니다. 예:
예:
PHP 코드
header()와 유사하게 사용하세요.
참고:
a.
b.
c.
4. 원칙.
a. 서버는 응답과 함께 http Set-Cookie 헤더를 전송하여 클라이언트에 쿠키를 설정합니다(여러 쿠키에는 여러 헤더가 필요함).
b. 클라이언트는 자동으로 http 쿠키 헤더를 서버에 보내고 서버는 이를 수신하여 읽습니다.
HTTP/1.x 200 OK
18:52:00 GMT
캐시 제어: 저장 안 함, 캐시 안 함, 재검증 필수, 사후 확인=0, 사전 확인=0
Pragma: no-cache
Content-type : text/html
Set-Cookie: TestCookie=something from another; path=/
브라우저는 클라이언트 디스크에 쿠키 파일을 생성하고 여기에 씁니다:
이 줄은 setcookie('TestCookie','something from someone','/');를 사용한 결과입니다. 이것이
header('Set-Cookie: TestCookie=something from someone; path=/');를 사용한 결과입니다.
--------- ------ ------구분선---------- -------- ---------------- --------
PHP 세션
세션의 핵심 개념은 웹 페이지 간 이동을 위한 추가 데이터로, 서버에 저장되고 ID로 식별되며 browsered 세션을 유지하려면 서버는 각 제출 시 이 ID를 가져와야 합니다.
------------ -- ------------------------------------------------ -- ------------------------------------------------ -- ---------
세션 ID를 전달하는 방법에는 두 가지가 있습니다:
a.
이 페이지에서 새 페이지로 이동하고 session_start()를 호출하면 PHP는 해당 ID에 저장된 세션 데이터를 확인합니다. 찾을 수 없으면 새 데이터 세트를 만듭니다.
b
xxx 그렇게 할 수도 있습니다 POST Pass 세션 값을 통해.
고객이 쿠키 사용을 금지하는 경우 다음과 같은 방법을 사용할 수 있습니다.
a. php.ini session.use_trans_sid = 1 또는 컴파일 시 --enable-trans-sid 옵션을 켜서 PHP가 자동으로 페이지 간에 세션 ID를 전달할 수 있도록 허용합니다.
b. URL을 통해 값을 수동으로 전달하고 숨겨진 양식을 통해 세션 ID를 전달합니다.
c. 파일, 데이터베이스 등에 session_id를 저장하고 페이지 간 프로세스 중에 수동으로 호출합니다.
링크:http://apps.hi.baidu.com/share/detail/41643457
쿠키가 비활성화된 경우에도 세션을 사용할 수 있습니다.
php.ini에서 Session.use_cookies=1을 0으로 변경하면 세션이 클라이언트 쿠키가 아닌 서버측에 저장됩니다.
session.save_path를 통해 서버의 세션 저장 위치를 확인할 수 있습니다
세션 사용량:
예:
PHP 코드
]; 🎜>
// 단일 세션 인쇄
session_destroy();
setcookie(session_name(),''
$_SESSION
= array
();
---------------------- - ------------------------------------------------- - ------------------------------------------------- - ---
간단한 예:
php 코드:
PHP 코드
Accept-Encoding: gzip , deflate User-Agent: Mozilla/4.0(호환; MSIE 6.0; Windows NT 5.1; Maxthon; .NET CLR 1.1.4322) 호스트: localhost
연결 유지
서버가 처음으로 돌아왔습니다:
HTTP/1.1 200 OK날짜: 2005년 8월 26일 금요일 07:44:22 GMT 서버: Apache/2.0.54 (Win32) SVN/1.2.1 PHP/5.0.4 DAV/2 X-Powered-By: PHP/5.0.4 쿠키 설정: PHPSESSID=bmmc3mfc94ncdr15ujitjogma3; path=/
만료: 1981년 11월 19일 목요일 08:52:00 GMT
캐시 제어: 아니요 -store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache
Content-Length: 1
Keep-Alive: timeout=15, 최대 =99
연결: 연결 유지
콘텐츠 유형: text/html; charset=utf-8 콘텐츠 언어: 꺼짐
서버에 대한 두 번째 요청:
GET /test.php HTTP/1.1
수락: */*
참조자: http://localhost /
수락 언어: zh-cn
수락 인코딩: gzip, deflate
사용자 에이전트: Mozilla/4.0(호환; MSIE 6.0; Windows NT 5.1; SV1; Maxthon; .NET CLR 1.1.4322)
호스트: localhost
연결: Keep-Alive
쿠키: PHPSESSID=bmmc3mfc94ncdr15ujitjogma3
서버가 반환되었습니다. 두 번째: HTTP/1.1 200 OK 이러한 출력을 주의 깊게 비교해 보면 두 번째 요청에 첫 번째 요청보다 더 많은 정보가 있습니다. 쿠키: PHPSESSID =bmmc3mfc94ncdr15ujitjogma3 . > 세션을 사용하는 동안 해당 세션은 쿠키를 통해 클라이언트 브라우저로 전송됩니다 실제로는 세션은 완전히 추상적인 개념입니다. 세션에 실제로 필요한 것은 http에서 제공하는 get 및 post에서 제공하는 매개변수 외에도 특정 사용자(예: 브라우저, 컴퓨터 또는 컴퓨터)에 대한 추가 정보를 저장할 수 있다는 것입니다. 심지어 IP). 시스템에서 제공하는 세션을 사용하지 않는 경우 데이터를 전송할 수도 있습니다. 예를 들어 원래 세션에 저장하려는 데이터를 직렬화한 다음 암호화하여 문자열을 형성하고 모든 URL과 양식에 전달할 수 있습니다. 페이지. 서버는 페이지 요청을 받은 후 get 또는 post에서 비밀 문자열을 꺼내서 발견하고 데이터를 복원합니다. 이는 실제로 세션과 동일합니다. 단지 이 방법이 매우 훌륭하고 구현하려면 추가 작업이 너무 많이 필요하다는 것뿐입니다. 기술적인 관점에서 세션은 웹 페이지 링크 사이에 저장될 추가 데이터의 이름을 ID로 지정하고 이를 서버 측에 저장하는 것입니다. 이전에 저장된 데이터를 얻을 수 있습니다. PHP는 기본적으로 파일을 사용하여 데이터를 저장합니다. Unix에서 PHP는 일반적으로 /tmp 아래에 "sess_"+$session_id와 같은 파일 이름을 생성합니다. 이 이름을 통해 session_id에 해당하는 데이터를 직접 찾을 수 있습니다. 따라서 세션의 가장 핵심 개념은 웹 페이지 간 이동을 위한 추가 데이터가 서버에 저장되고 ID로 식별된다는 것입니다. 세션을 유지하려면 브라우저가 제출할 때마다 이 ID를 가져와야 합니다. 서버에 요청이 있을 때마다 로컬 브라우저는 요청 정보에 쿠키를 첨부합니다. 사실 , 세션이 그것과 아무 관련이 없는 것과 동일하며 단지 http 프로토콜에서 쿠키가 작동하는 방식에 관한 것입니다. 이 쿠키는 session_start() 함수에 의해 작성되며 쿠키가 작성되고 유효 기간이 만료되지 않은 한 브라우저에서 쿠키를 보낼 수 있습니다.
날짜: 2005년 8월 26일 금요일 07:44:23 GMT
서버: Apache/2.0.54(Win32) SVN/1.2. 1 PHP/5.0.4 DAV/2
X-Powered-By: PHP/5.0.4
Set-Cookie: PHPSESSID=bmmc3mfc94ncdr15ujitjogma3; path=/ :00 GMT
캐시 제어: no-store , no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache
Content-Length: 1
Keep-Alive: timeout=15, max=98
연결: 연결 유지
콘텐츠 유형: text/html; charset=utf-8
콘텐츠 언어: 꺼짐
이 헤더는 서버에 쿠키 정보를 보냅니다. 서버에 PHPSESSID라는 쿠키가 있고 내용은 bmmc3mfc94ncdr15ujitjogma3이라고 알려줍니다.
이 쿠키는 어디서 왔나요? 처음으로 서버에서 반환된 정보를 살펴보세요.
Set-Cookie: PHPSESSID=bmmc3mfc94ncdr15ujitjogma3; path=/
서버가 클라이언트 브라우저에 쿠키를 쓰는 것입니다. 이름은 PHPSESSID이고 값은 다음과 같습니다. bmmc3mfc94ncdr15ujitjogma3. 이 값은 실제로 소위 session_id입니다.
서버에 대한 두 번째 요청을 계속 살펴보면 PHPSESSID 쿠키가 여전히 서버로 전송됩니다.
다음과 같은 결론을 내릴 수 있습니다.
1. 서버는 세션을 보냅니다
2. 서버에 요청이 있을 때마다 로컬 브라우저는 요청 정보에 쿠키를 첨부합니다
브라우저는 어떻게 모든 요청에 대해 이 ID를 가져올 수 있습니까? 물론 일부 웹메일에서는 실제로 이 작업을 수행하는 각 URL 링크 또는 양식 게시물에 ID 매개변수를 추가합니다. 물론, 가장 쉬운 방법은 쿠키를 통해 저장하는 것입니다. 하지만 쿠키 해결 방법에는 여전히 문제가 있습니다.위에서 설명한 것처럼 브라우저가 쿠키를 지원하지 않는 경우 어떻게 해야 합니까?
위에서 언급한 세션은 php4 및 5에서 제공하는 세션 기능입니다. php4 이전에는 세션 기능을 제공하지 않았습니다! 그리고 많은 CGI 프로그램은 완전히 자체 구현된 세션입니다. php(4,5)에서 제공하는 세션의 경우 시스템은 기본적으로 쿠키를 사용하여 session_id를 저장합니다.
이전 프로젝트에서는 사용자가 모두 인트라넷에서 웹을 사용했습니다. 관리를 용이하게 하기 위해 브라우저 IP는 세션에 직접 연결됩니다. 즉, sessionid 대신 브라우저 IP 주소가 사용됩니다. 이 솔루션에는 쿠키가 없지만 세션 정의를 벗어나지 않으므로 여전히 세션입니다.
위 내용은 PHP 버전 - HTTP 세션 쿠키 원리 및 적용 내용을 포함하여 소개되었으며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.