세션 처리는 PHP에서 매우 중요한 개념으로, 이를 통해 웹사이트나 애플리케이션의 모든 페이지에서 사용자 정보가 변경되지 않은 상태로 유지됩니다.
PHP에서 세션이란 무엇인가요?
세션은 사용자가 웹사이트나 애플리케이션을 탐색할 때 사용자를 식별하기 위해 다양한 웹페이지에 대한 정보를 유지하는 메커니즘입니다.
모든 사람은 다음 질문을 갖고 있어야 합니다. 웹사이트에 세션이 필요한 이유는 무엇입니까? 이 문제를 논의하기 전에 돌아가서 HTTP 프로토콜이 어떻게 작동하는지 살펴봐야 합니다.
HTTP 프로토콜은 상태 비저장 프로토콜입니다. 즉, 서버는 요청 간에 특정 사용자를 기억할 수 없습니다. 예를 들어, 귀하가 웹페이지를 방문하면 서버는 요청된 페이지의 콘텐츠를 제공하는 역할만 담당합니다. 따라서 동일한 웹사이트의 다른 페이지를 방문하면 웹 서버는 각 요청이 서로 아무 관련이 없는 것처럼 개별적으로 해석합니다. 서버는 모든 요청이 동일한 사용자로부터 온다는 것을 알 수 없습니다.
(무료 학습 동영상 튜토리얼: php 동영상 튜토리얼)
다음 그림은 HTTP 프로토콜을 간략하게 설명합니다.
이 과정에서 특정 사용자의 정보를 표시하려면 각 요청에서 해당 사용자를 인증해야 합니다. 요청할 때마다 인증을 위해 페이지에 사용자 이름과 비밀번호를 입력해야 한다고 상상해 보세요. 이는 너무 지루하고 전혀 실용적이지 않습니다. 그러나 이때 세션이 유용합니다.
세션을 통해 사용자는 단일 사이트나 애플리케이션의 여러 페이지에서 정보를 공유할 수 있으므로 상태를 유지하는 데 도움이 됩니다. 이를 통해 서버는 모든 요청이 동일한 사용자로부터 오는 것임을 알 수 있으며 사이트에서 사용자별 정보와 기본 설정을 표시할 수 있습니다.
아래 다이어그램은 세션에서 HTTP 프로토콜이 사용되는 방법을 설명합니다.
PHP는 세션을 어떻게 처리하나요?
1. 세션 시작
세션 변수를 처리하려면 항상 세션이 시작되었는지 확인해야 합니다. PHP에서 세션을 시작하는 방법에는 여러 가지가 있습니다.
1), session_start 함수를 사용하세요
이것은 session_start 함수에 의해 세션이 시작되는 가장 일반적인 방법입니다.
출력이 브라우저에 전송되기 전에 스크립트 시작 부분에서 session_start 함수를 호출하는 것이 중요합니다. 그렇지 않으면 악명 높은 헤더가 이미 전송되었습니다 오류가 발생합니다.
2) 자동으로 세션 시작
애플리케이션 전체에서 세션을 사용해야 하는 경우 session_start 함수를 사용하지 않고 세션을 자동으로 시작하도록 선택할 수도 있습니다.
php.ini 파일에는 각 요청에 대해 세션을 자동으로 시작할 수 있는 구성 옵션 session.auto_start가 있습니다. 기본적으로 0으로 설정되어 있으며, 1로 설정하여 자동 시작 기능을 활성화할 수 있습니다.
2. 세션 ID 가져오기
서버는 새 세션마다 고유 ID를 생성합니다. 세션 ID를 얻으려면 다음 스니펫에 표시된 대로 session_id 함수를 사용할 수 있습니다.
이렇게 하면 현재 세션 ID가 제공됩니다. session_id 함수는 세션 ID라는 하나의 매개변수도 사용할 수 있다는 점에서 흥미롭습니다. 시스템 생성 세션 ID를 자신의 것으로 바꾸려면 session_id 함수의 첫 번째 매개변수에 이를 제공할 수 있습니다.
맞춤 세션 ID로 세션을 시작하려면 session_start 전에 session_id 함수를 호출해야 한다는 점에 유의하는 것이 중요합니다.
3. 세션 변수 생성
세션이 시작되면 $_SESSION은 해당 세션 정보로 슈퍼 전역 배열을 초기화합니다. 기본적으로 빈 배열로 초기화되며 키-값 쌍을 사용하여 더 많은 정보를 저장할 수 있습니다.
코드 예시를 통해 세션 변수를 초기화하는 방법을 살펴보겠습니다.
위에 표시된 것처럼 session_start 함수를 사용하여 스크립트 시작 부분에서 세션을 시작한 후 마지막으로 여러 세션 변수를 초기화합니다. , $를 사용합니다. _SESSION 슈퍼전역은 이러한 변수에 액세스합니다.
$_SESSION 슈퍼전역을 사용하여 세션에 데이터를 저장하면 최종적으로 세션 시작 시 생성되는 서버의 해당 세션 파일에 저장됩니다. 이런 방식으로 세션 데이터는 여러 요청에서 공유됩니다.
논의한 대로 세션 정보는 요청 간에 공유되므로 한 페이지에서 초기화된 세션 변수는 세션이 만료될 때까지 다른 페이지에서도 액세스할 수 있습니다. 일반적으로 브라우저를 닫으면 세션이 만료됩니다.
4. 세션 변수 수정 및 삭제
일반 PHP 변수를 수정하는 것처럼 기존에 애플리케이션에서 생성한 세션 변수를 수정하거나 삭제할 수 있습니다.
세션 변수를 수정하는 방법을 예시를 통해 살펴보겠습니다.
위 스크립트에서는 먼저 $_session['count'] 변수가 설정되어 있는지 확인합니다. 설정되어 있지 않으면 1로 설정하고, 그렇지 않으면 1씩 증가시킵니다. 따라서 이 페이지를 여러 번 새로 고치면 카운터가 매번 1씩 증가하는 것을 볼 수 있습니다!
반면에 세션 변수를 삭제하려면 다음 코드 조각과 같이 unset 함수를 사용할 수 있습니다.
이러한 방식으로 더 이상 $_SESSION[' logged_in_user_id'] 변수. unset 함수에 의해 삭제되었기 때문입니다.
5. 세션 삭제
위에서 unset 함수를 사용하여 특정 세션 변수를 삭제할 수 있다는 것을 알고 있는데, 세션 관련 데이터를 모두 삭제하려면 어떻게 해야 할까요?
실제로는 매우 간단합니다. session_destroy 함수를 사용할 수 있습니다.
session_destroy 함수가 어떻게 작동하는지 살펴보겠습니다.
설명: session_destroy 함수는 현재 세션에 저장된 모든 콘텐츠를 삭제합니다. 따라서 session_destroy 함수에 의해 디스크에 저장된 세션 데이터가 삭제되면 후속 요청에서 빈 세션 변수가 표시됩니다.
참고: 일반적으로 session_destroy 함수는 사용자가 로그아웃할 때 사용됩니다.
권장 관련 기사 및 튜토리얼: php 튜토리얼
위 내용은 PHP 세션 처리 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!