백엔드 개발 PHP 튜토리얼 PHP에서 쿠키와 세션의 차이점과 쿠키와 세션의 사용법에 대한 자세한 설명

PHP에서 쿠키와 세션의 차이점과 쿠키와 세션의 사용법에 대한 자세한 설명

Jul 10, 2017 am 10:06 AM
cookie php session

이 글은 주로 PHP에서의 쿠키와 session의 차이점과 쿠키 및 세션 사용 요약에 대한 관련 정보를 소개합니다. 매우 좋고 도움이 필요한 친구들이 참고할 수 있습니다.

구체적으로는, 쿠키는 "클라이언트"에 저장되고 세션은 "서버"에 저장됩니다.

쿠키는 http 프로토콜을 확장하여 구현됩니다.

쿠키에는 주로 이름, 값, 만료 시간, 경로 및 도메인이 포함됩니다.

쿠키에

수명 주기가 설정되어 있지 않으면 브라우저를 닫을 때 닫힙니다. 이러한 유형의 쿠키는 일반적으로 하드 디스크가 아닌 메모리에 저장됩니다. 그 반대는 사실입니다. 이 쿠키는 설정된 만료 시간이 초과될 때까지 계속 유효합니다.

세션은 해시 테이블과 같은 형식으로 정보를 저장합니다.


프로그램이 클라이언트 요청에 대한 세션을 생성해야 할 때 서버는 먼저 클라이언트의 요청에 이미 세션 식별자(세션 ID라고 함)가 포함되어 있는지 확인합니다. )이 포함되어 있으면 이전에 이 클라이언트에 대한 세션이 생성되었음을 의미합니다. 서버는 세션 ID에 따라 이 세션을 검색하여 사용합니다(검색할 수 없는 경우 새 세션을 생성합니다). 클라이언트 요청에 세션 ID가 포함되지 않은 경우 이 클라이언트에 대한 세션을 만들고 이 세션과 연결된 세션 ID를 생성합니다. 세션 ID 값은 반복적이지도 않고 위조 패턴을 찾기도 쉽지 않은

string
이어야 합니다. . 이 세션 ID는 저장을 위해 이 응답으로 클라이언트에 반환됩니다. 이 세션 ID를 저장하는 방법은 쿠키를 사용하여 상호 작용 프로세스 중에 브라우저가 규칙에 따라 이 ID를 서버에 자동으로 보낼 수 있도록 하는 것입니다. 일반적으로 이 쿠키의 이름은 SEEESIONID와 유사합니다. 그러나 쿠키는 인위적으로 비활성화될 수 있으며 쿠키가 비활성화된 경우 세션 ID를 서버에 다시 전달하는 다른 메커니즘이 있어야 합니다.


장점과 단점:


1. 쿠키 데이터는 고객의 브라우저에 저장되고, 세션 데이터는 서버에 저장됩니다.

2. 쿠키는 그다지 안전하지 않습니다. 다른 사람이 로컬에 저장된 쿠키를 분석하여 속일 수 있습니다.

보안을 고려하여 세션을 사용해야 합니다.

3. 세션은 일정 기간 동안 서버에 저장됩니다. 접속량이 증가하면 서버 성능을 더 많이 차지하게 됩니다

서버 성능을 저하시키려면 COOKIE를 사용해야 합니다.

4. 단일 쿠키로 저장되는 데이터는 4K를 초과할 수 없습니다. 많은 브라우저는 사이트에 최대 20개의 쿠키를 저장하도록 제한합니다.


5. 개인적인 제안:


로그인 정보 등 중요한 정보를 SESSION

으로 저장하세요. 다른 정보를 보관해야 하는 경우 COOKIE


에 넣을 수 있습니다. 세션 및 쿠키 사용 요약:


세션과 쿠키는 모두
asp.Net
에 내장된 개체입니다. 차이점에 대해서는 여기서 자세히 설명하지 않겠습니다.

우리는 그것을 알고 있습니다. 웹사이트에는 백엔드 관리 기능이 있습니다. 시스템에는 로그인과 로그아웃이라는 두 가지 기능이 있습니다. 로그인 시 나중에 사용하기 위해 사용자 정보를 세션이나 쿠키에 저장하는 경우가 많습니다.

1. 민감한 사항은 세션에 저장합니다. 예를 들어 사용자 이름은 그다지 민감하지 않지만 일부 브라우저에서는 쿠키 사용을 지원하지 않으므로 저장합니다. 그러나 세션이 서버에서 쉽게 사라지는 경우가 있으므로 쿠키와 함께 사용할 수 있습니다. 즉, 세션이 손실되었을 때 쿠키가 아직 설정한 유효 기간 내에 있으면 쿠키를 사용할 수 있습니다. 쿠키에서 값을 가져와서 세션에 넣기 때문에 세션과 쿠키를 사용하여 사용자 이름과 기타 정보를 동시에 저장하거나

구성 파일

에 저장하는 것이 좋습니다. 코드는 다음과 같습니다.

세션 손실 문제를 해결하려면

2. 오랫동안 작업이 없으면 백그라운드 관리에서 세션을 무효화하고 다시 로그인하기를 바랍니다. session.timeout=5를 사용하면 됩니다. 즉, 5분 이내에 다른 작업이 없으면 만료됩니다. 또는 구성 파일에서 를 구성할 수도 있습니다


3 . 쿠키 유효 기간 설정


httpCookie.Expires = DateTime.Now.AddMinutes(2);


쿠키의 유효 기간은 2분입니다


4. 페이지를 다음과 같이 판단할 수 있습니다.

if (Request.Cookies["httpCookie"] != null)
{
Session["admin"] = Request.Cookies["httpCookie"].Values["admin"].ToString();
}
if (Session["admin"] == null)
{
this.ClientScript.RegisterStartupScript(this.GetType(), "", "<script>alert(&#39;请重新登 录&#39;);location.href=&#39;logins.aspx&#39;</script>");
}
로그인 후 복사

이제 종료할 때 해야 할 일에 대해 이야기해 보겠습니다.

1. 종료할 때 세션과 쿠키의 값이 지워집니다. 이제 간단히 이야기해 보겠습니다. 여러 세션 방법의 차이점:

Session.clear(): 세션의 모든 세션 키 값이 지워지지만 세션은 여전히 ​​존재함을 나타냅니다. Session.RemoveAll()

Session["admin"]=null과 동일합니다. 키가 지정됩니다. 값이 지워지고 해제됩니다. 이는 session["admin"]=""과 다릅니다. 지워지지만 세션이 해제되지 않습니다. 이는 session.Remove("name");
과 동일합니다.

Session.Abandon()은 현재 Session 객체가 삭제되고, 다음 세션은 새로운 Session이 됩니다.

가장 큰 차이점은 Session.Abandon을 사용할 때 Session_End 메서드(InProc 모드에서)가 호출된다는 것입니다. 다음 요청이 오면 Session_Start 메소드가 실행됩니다. Session.Clear는 세션의 모든 데이터만 지우고 세션을 종료하지 않으므로 해당 메서드는 호출되지 않습니다. Abandon 메서드는 세션 시간이 초과될 때 적극적으로 세션을 종료하는 데 사용됩니다. 또한 현재 세션을 자동으로 종료합니다.

2. 쿠키를 삭제하는 방법을 살펴보겠습니다

A.tpCookie cookie = System.Web.HttpContext.
Current

.Request.Cookies.Get("tuser");

cookie.Expires = DateTime . Now.AddDays(-1);System.Web.HttpContext.Current.Response.Cookies.Add(cookie);

B, tpCookie httpCookie = Request.Cookies["httpCookie"];

httpCookie.Expires = DateTime .Now.AddDays(-1);

Response.Cookies.Add(httpCookie);



AB 두 가지 방법을 모두 사용할 수 있습니다

3. 세션의 현재 값, 즉 Session["admin]을 삭제하세요. '] =null이면 괜찮으며 위의 방법에 따라 쿠키를 지울 수 있습니다


제안 및 의견:

1 종료할 때 로그아웃 페이지를 만들어 시간을 기록할 수 있어 더 좋습니다

2. 어떤 작업을 수행하더라도 If를 사용하여 비어 있는지 판단할 수 있다면 널 포인터 예외 발생을 방지하기 위해 최선을 다하세요

위 내용은 PHP에서 쿠키와 세션의 차이점과 쿠키와 세션의 사용법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

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

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

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

이전에 몰랐던 후회되는 PHP 함수 7가지 이전에 몰랐던 후회되는 PHP 함수 7가지 Nov 13, 2024 am 09:42 AM

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

PHP에서 HTML/XML을 어떻게 구문 분석하고 처리합니까? PHP에서 HTML/XML을 어떻게 구문 분석하고 처리합니까? Feb 07, 2025 am 11:57 AM

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

JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. Apr 05, 2025 am 12:04 AM

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

문자열로 모음을 계산하는 PHP 프로그램 문자열로 모음을 계산하는 PHP 프로그램 Feb 07, 2025 pm 12:12 PM

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 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에서 늦은 정적 결합을 설명하십시오 (정적 : :). PHP에서 늦은 정적 결합을 설명하십시오 (정적 : :). Apr 03, 2025 am 12:04 AM

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

php magic 방법 (__construct, __destruct, __call, __get, __set 등)이란 무엇이며 사용 사례를 제공합니까? php magic 방법 (__construct, __destruct, __call, __get, __set 등)이란 무엇이며 사용 사례를 제공합니까? Apr 03, 2025 am 12:03 AM

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

See all articles