PHP 버전--HTTP 세션 쿠키 원칙 및 적용
PHP는 http 프로토콜의 헤더 정보에 쿠키를 보내기 때문에 브라우저에 다른 정보를 출력하기 전에 setcookie() 함수를 호출해야 하는데, 이는 header() 함수의 제한과 유사합니다.
1. 쿠키 설정:
a.
예:
PHP 코드
- $value = '어딘가에서 온 것'
- setcookie("TestCookie", $value) /* 간단한 쿠키 설정 */
- setcookie("TestCookie" , $value, time()+3600) /* 유효기간 1시간 */
- setcookie("TestCookie", $value, time()+3600, "/~rasmus/",
- ".example.com", 1) /* 유효한 디렉터리 /~rasmus, 유효한 도메인 이름 example.com 및 모든 하위 도메인 */
b.
예:
PHP 코드
- $value = '어딘가에서 온 것'; header("Set- 쿠키:이름=$값"
- );
---------------------------- ----------------- --------------------------------- ----------------- ---------------------------------
PHP 내장 슈퍼 전역 변수 $_COOKIE를 직접 사용하여 브라우저 측에서 쿠키를 읽습니다.
예:
PHP 코드
- 인쇄 $_COOKIE['TestCookie']
3.
그냥 유효한 시간을 현재 시간보다 작게 설정하고 값을 null로 설정합니다. 예:
예:
PHP 코드
- setcookie("name", "", time() - 1)
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 코드
- // page1.php
- session_start() ;
- echo '1페이지에 오신 것을 환영합니다'; 🎜>
- /* 세션 변수를 생성하고 세션 변수에 값 할당 */
- $_SESSION[' favcolor '] = '녹색' _SESSION['동물'
- ] = '고양이'; $_SESSION['시간' ] = time();
- // 클라이언트가 쿠키를 사용하는 경우 세션을 다음으로 직접 전달할 수 있습니다. page2.php
- 에코 '
2페이지' - // 클라이언트가 쿠키를 비활성화한 경우
- echo '
2페이지' - ; > /* 기본적으로 php5.2.1에서 SID는 다음과 같습니다. 쿠키에만 기록되는 값이 동시에
- 세션에 해당하는 쿠키가 있는 경우입니다. SID는 (정의되지 않음) 비어 있습니다.
- */
- >// page2.php
- session_start() ;
]; 🎜>
// 단일 세션 인쇄
- var_dump($_SESSION); // 1페이지 인쇄 .php에서 전달된 세션 값
- 세션 삭제:
- 예: PHP 코드
session_destroy();
setcookie(session_name(),''
$_SESSION
= array
- // 3단계: $_SESSION 전역 변수 배열 삭제 ?>
-
---------------------- - ------------------------------------------------- - ------------------------------------------------- - ---
간단한 예:
php 코드:
PHP 코드
- session_start()
- if (isset($_SESSION ['test_sess'])){
- $_SESSION['test_sess']++;
- }그밖에{
- $_SESSION[' test_sess'] = 0; 🎜>
- 에코
- $_SESSION['테스트_세스'
- ]; >는 httplook이라는 http 패킷 스니핑 도구를 사용하여 패킷을 캡처했습니다.
- 서버에 대한 첫 번째 요청: GET /test.php HTTP/1.1 수락: */ *
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
날짜: 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
이 헤더는 서버에 쿠키 정보를 보냅니다. 서버에 PHPSESSID라는 쿠키가 있고 내용은 bmmc3mfc94ncdr15ujitjogma3이라고 알려줍니다.
이 쿠키는 어디서 왔나요? 처음으로 서버에서 반환된 정보를 살펴보세요.
Set-Cookie: PHPSESSID=bmmc3mfc94ncdr15ujitjogma3; path=/
서버가 클라이언트 브라우저에 쿠키를 쓰는 것입니다. 이름은 PHPSESSID이고 값은 다음과 같습니다. bmmc3mfc94ncdr15ujitjogma3. 이 값은 실제로 소위 session_id입니다.
서버에 대한 두 번째 요청을 계속 살펴보면 PHPSESSID 쿠키가 여전히 서버로 전송됩니다.
다음과 같은 결론을 내릴 수 있습니다.
1. 서버는 세션을 보냅니다
2. 서버에 요청이 있을 때마다 로컬 브라우저는 요청 정보에 쿠키를 첨부합니다. >
요약:세션을 사용하는 동안 해당 세션은 쿠키를 통해 클라이언트 브라우저로 전송됩니다
실제로는 세션은 완전히 추상적인 개념입니다. 세션에 실제로 필요한 것은 http에서 제공하는 get 및 post에서 제공하는 매개변수 외에도 특정 사용자(예: 브라우저, 컴퓨터 또는 컴퓨터)에 대한 추가 정보를 저장할 수 있다는 것입니다. 심지어 IP). 시스템에서 제공하는 세션을 사용하지 않는 경우 데이터를 전송할 수도 있습니다. 예를 들어 원래 세션에 저장하려는 데이터를 직렬화한 다음 암호화하여 문자열을 형성하고 모든 URL과 양식에 전달할 수 있습니다. 페이지. 서버는 페이지 요청을 받은 후 get 또는 post에서 비밀 문자열을 꺼내서 발견하고 데이터를 복원합니다. 이는 실제로 세션과 동일합니다. 단지 이 방법이 매우 훌륭하고 구현하려면 추가 작업이 너무 많이 필요하다는 것뿐입니다. 기술적인 관점에서 세션은 웹 페이지 링크 사이에 저장될 추가 데이터의 이름을 ID로 지정하고 이를 서버 측에 저장하는 것입니다. 이전에 저장된 데이터를 얻을 수 있습니다. PHP는 기본적으로 파일을 사용하여 데이터를 저장합니다. Unix에서 PHP는 일반적으로 /tmp 아래에 "sess_"+$session_id와 같은 파일 이름을 생성합니다. 이 이름을 통해 session_id에 해당하는 데이터를 직접 찾을 수 있습니다. 따라서 세션의 가장 핵심 개념은 웹 페이지 간 이동을 위한 추가 데이터가 서버에 저장되고 ID로 식별된다는 것입니다. 세션을 유지하려면 브라우저가 제출할 때마다 이 ID를 가져와야 합니다.
브라우저는 어떻게 모든 요청에 대해 이 ID를 가져올 수 있습니까? 물론 일부 웹메일에서는 실제로 이 작업을 수행하는 각 URL 링크 또는 양식 게시물에 ID 매개변수를 추가합니다. 물론, 가장 쉬운 방법은 쿠키를 통해 저장하는 것입니다. 하지만 쿠키 해결 방법에는 여전히 문제가 있습니다.위에서 설명한 것처럼 브라우저가 쿠키를 지원하지 않는 경우 어떻게 해야 합니까?
위에서 언급한 세션은 php4 및 5에서 제공하는 세션 기능입니다. php4 이전에는 세션 기능을 제공하지 않았습니다! 그리고 많은 CGI 프로그램은 완전히 자체 구현된 세션입니다. php(4,5)에서 제공하는 세션의 경우 시스템은 기본적으로 쿠키를 사용하여 session_id를 저장합니다.
이전 프로젝트에서는 사용자가 모두 인트라넷에서 웹을 사용했습니다. 관리를 용이하게 하기 위해 브라우저 IP는 세션에 직접 연결됩니다. 즉, sessionid 대신 브라우저 IP 주소가 사용됩니다. 이 솔루션에는 쿠키가 없지만 세션 정의를 벗어나지 않으므로 여전히 세션입니다.서버에 요청이 있을 때마다 로컬 브라우저는 요청 정보에 쿠키를 첨부합니다.
사실 , 세션이 그것과 아무 관련이 없는 것과 동일하며 단지 http 프로토콜에서 쿠키가 작동하는 방식에 관한 것입니다. 이 쿠키는 session_start() 함수에 의해 작성되며 쿠키가 작성되고 유효 기간이 만료되지 않은 한 브라우저에서 쿠키를 보낼 수 있습니다.
위 내용은 PHP 버전 - HTTP 세션 쿠키 원리 및 적용 내용을 포함하여 소개되었으며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

숙련된 PHP 개발자라면 이미 그런 일을 해왔다는 느낌을 받을 것입니다. 귀하는 상당한 수의 애플리케이션을 개발하고, 수백만 줄의 코드를 디버깅하고, 여러 스크립트를 수정하여 작업을 수행했습니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

PHP의 마법 방법은 무엇입니까? PHP의 마법 방법은 다음과 같습니다. 1. \ _ \ _ Construct, 객체를 초기화하는 데 사용됩니다. 2. \ _ \ _ 파괴, 자원을 정리하는 데 사용됩니다. 3. \ _ \ _ 호출, 존재하지 않는 메소드 호출을 처리하십시오. 4. \ _ \ _ get, 동적 속성 액세스를 구현하십시오. 5. \ _ \ _ Set, 동적 속성 설정을 구현하십시오. 이러한 방법은 특정 상황에서 자동으로 호출되어 코드 유연성과 효율성을 향상시킵니다.
