목차
1. 쿠키
2. 세션에 대한 자세한 설명
3. 세션과 쿠키의 차이점:
백엔드 개발 PHP 튜토리얼 쿠키, 세션, 저장 기능 요약

쿠키, 세션, 저장 기능 요약

Sep 18, 2017 am 10:21 AM
cookie session storage


1. 쿠키

1. 쿠키: 클라이언트와 서버 간의 상호 작용 정보를 기록합니다.
쿠키 사양은 서버와 클라이언트 간의 대화형 정보의 형식, 수명, 사용 범위 및 보안을 정의합니다.
이 정보는 JavaScript의 document.cookie를 통해 읽거나 설정할 수 있습니다. 쿠키는 주로 클라이언트와 서버 간의 통신에 사용되므로 JavaScript 외에 서버측 언어(예: PHP)에서도 쿠키에 접근할 수 있습니다.

2. 쿠키는 원격 브라우저에 데이터를 저장하고 이를 사용하여 사용자를 추적하고 식별하는 메커니즘입니다. 구현 측면에서 쿠키는 클라이언트에 저장된 작은 데이터 조각입니다. 브라우저(즉, 클라이언트)는 HTTP 프로토콜을 통해 서버와 상호 작용합니다. 쿠키에는 크기 제한이 있으며 각 쿠키에 저장되는 데이터는 4kb를 초과할 수 없습니다. 쿠키 문자열의 길이가 4kb를 초과하면 이 속성은 빈 문자열을 반환합니다.

3. 쿠키는 브라우저에 의해 구현되고 관리됩니다.

4. 쿠키 자체의 속성에는 "Comment", "Domain", "Max-Age", "Path", "Secure", "Version"이 포함됩니다. 구체적인 사용법은 JavaScript 운영 쿠키를 참조하세요.

Comment 속성은 쿠키에 의해 생성된 쿠키에 대한 설명입니다.

Domain 속성은 일부 대규모 웹사이트의 경우 쿠키를 하위에서 공유하려는 경우에 정의됩니다. -사이트, 이 속성을 사용할 수 있습니다. 예를 들어 도메인이 .bigsite.com으로 설정된 경우 sub1.bigsite.com과 sub2.bigsite.com 모두 클라이언트에 저장된 쿠키에 액세스할 수 있습니다. 이 경우 경로를 /로 설정해야 합니다.

Max-Age 속성은 쿠키의 유효 시간을 초 단위로 정의합니다. 유효 기간이 초과되면 쿠키 정보가 HTTP 메시지 헤더를 통해 클라이언트에서 서버로 전송되지 않습니다.

Path 속성은 쿠키에 접근할 수 있는 웹사이트의 페이지 경로를 정의합니다. 기본적으로 Path는 쿠키가 생성될 때의 경로입니다. 이 경로 아래의 페이지에서 쿠키에 접근할 수 있습니다. 해당 하위 경로는 /로 설정될 수 있으므로 해당 웹사이트의 모든 페이지에서 쿠키에 접근할 수 있습니다.

Secure 속성 값은 쿠키의 보안을 정의합니다. 값이 true인 경우 쿠키가 클라이언트의 HTTP 메시지에 첨부되어 서버로 전송되기 전에 쿠키가 HTTPS 상태에 있어야 합니다. 쿠키는 전송되지 않습니다. Secure는 false인 경우 쿠키가 HTTP 상태로 전달될 수 있습니다.

Version 속성은 쿠키 작성자가 정의한 대로 쿠키의 버전을 정의합니다.

5. 쿠키 사용:
기록되는 정보는 서버에서 생성된 후 클라이언트로 전달됩니다. HTTP 메시지에서 정보를 꺼내 로컬 디스크에 저장합니다. 클라이언트가 서버에 다시 접속하면 로컬 디스크에서 원래 저장된 정보를 읽어서 HTTP 메시지에 첨부하여 서버로 보냅니다. 서버는 HTTP 메시지의 정보를 읽고 필요에 따라 추가 처리를 수행합니다. 실제 응용 프로그램.

6. 쿠키 정보는 텍스트 파일에 일반 텍스트로 저장되므로 비밀번호, 은행 계좌 번호 등 일부 민감한 정보를 로컬 쿠키 파일에 저장하려면 암호화된 형식을 사용하는 것이 가장 좋습니다.

2. 세션에 대한 자세한 설명

1. 세션은 답장으로, 지속적인 양방향연결을 의미합니다. 세션과 쿠키 사이에는 본질적으로 차이가 없습니다. 둘 다 HTTP 프로토콜의 제한 사항에 대응하여 클라이언트와 서버 간의 세션 연결 상태를 유지하기 위해 제안된 메커니즘입니다. 세션 역시 보편적인 표준이지만 언어에 따라 다르게 구현됩니다. 웹사이트의 경우, 세션은 사용자가 웹사이트에 접속한 시점부터 웹사이트를 탐색할 때 브라우저를 닫을 때까지의 세션을 의미합니다. 세션은 사실 시간이라는 특정한 개념입니다.
2. 세션은 세션 파일의 파일명인 세션 ID를 통해 클라이언트 사용자를 결정합니다. sessionID는 실제로 HTTP 요청과 HTTP 응답을 통해 클라이언트와 서버 간에 전달됩니다. sessionID는 특정 알고리즘에 따라 생성되며 세션 보안을 보장하기 위해 고유성과 임의성을 보장하기 위해 HTTP 요청에 포함되어야 합니다. 세션 생성 주기가 설정되어 있지 않으면 세션 ID가 메모리에 저장되며, 해당 ID는 브라우저를 닫은 후 자동으로 로그아웃되며, 페이지를 다시 요청하면 세션 ID가 다시 등록됩니다. 클라이언트가 쿠키를 비활성화하지 않으면 쿠키는 세션 세션을 시작할 때 세션 ID와 세션 수명을 저장하는 역할을 합니다. 세션이 만료되면 PHP는 세션을 재활용합니다.

3. 세션과 쿠키의 차이점:

1. 세션은 서버 측에 있고 쿠키는 클라이언트 측(브라우저)에 있습니다.
2. 세션은 메모리가 아닌 서버의 파일에 존재합니다(기본값). 3. 세션 세션 ID의 실행 종속성과 세션 ID는 쿠키에 저장됩니다. 즉, 브라우저가 쿠키를 비활성화하면 세션도 유효하지 않게 됩니다(물론 URL로 전달될 수도 있음)
4. 세션은 파일, 데이터베이스 또는 메모리에 배치될 수 있습니다. 둘 다 괜찮습니다.
5. 세션은 일반적으로 사용자 확인을 위해 사용됩니다. 따라서 세션을 유지하는 핵심은 클라이언트의 고유 식별자, 즉 세션 ID입니다.
6. 세션이 너무 많은 메모리를 차지하면 부담이 됩니다. 서버 서비스 성능. 쿠키에 의해 저장되는 데이터는 제한되어 있습니다.
7. 세션은 개체를 저장하고, 쿠키는 문자열 유형의 키-값 쌍을 저장합니다.

설명: HTTP 프로토콜은 상태 비저장 프로토콜이므로 서버가 사용자의 상태를 기록해야 할 때 특정 사용자를 식별하기 위해 몇 가지 메커니즘을 사용해야 합니다. 이 메커니즘은 쇼핑과 같은 것입니다. 장바구니를 클릭하면 HTTP 프로토콜은 어떤 사용자가 이를 운영하는지 알 수 없으므로 서버는 특정 사용자에 대한 특정 세션을 생성하여 사용자를 식별해야 합니다. 장바구니에 책이 많이 있어요. 이 세션은 서버 측에 저장되며 고유 식별자를 갖습니다.
메모리, 데이터베이스, 파일 등 세션을 서버 측에 저장하는 방법은 다양합니다. 클러스터링 시 세션 전송도 고려해야 합니다. 일반적으로 사용자 세션을 저장하기 위해 전용 세션 서버 클러스터가 있습니다. 이때 세션 정보는 메모리에 저장되며 Memcached와 같은 일부 캐싱 서비스가 사용됩니다. 세션. 생각해 보세요
서버는 어떻게 특정 고객을 식별하나요? 이때 Cookie가 무대에 등장합니다. HTTP 요청이 이루어질 때마다 클라이언트는 해당 쿠키 정보를 서버에 보냅니다. 실제로 대부분의 애플리케이션은 세션 추적을 구현하기 위해 쿠키를 사용합니다. 세션이 처음 생성되면 서버는 세션 ID가 쿠키에 기록되어야 함을 HTTP 프로토콜로 클라이언트에 알려줍니다. 후속 요청을 통해 세션 ID가 서버로 전송되며 귀하가 누구인지 알 수 있습니다. 누군가가 클라이언트의 브라우저가 쿠키를 비활성화하면 어떻게 해야 합니까?라고 물었습니다. 일반적으로 이 경우 세션 추적을 위해 URL 재작성이라는 기술이 사용됩니다. 즉, 각 HTTP 상호 작용에 대해 sid=xxxxx와 같은 매개 변수가 URL에 추가되고 이에 따라 서버가 사용자를 식별합니다. 쿠키는 실제로 일부 사용자 친화적인 시나리오에서 사용될 수 있습니다. 웹사이트에 한 번 로그인한 후 다음에 로그인할 때 다시 계정에 로그인하고 싶지 않다고 가정해 보세요. 이 정보는 쿠키에 기록될 수 있습니다. 웹사이트를 방문할 때 웹사이트 페이지의 스크립트가 이 정보를 읽고 자동으로 사용자 이름을 채워 사용자를 용이하게 할 수 있습니다. 이는 사용자에게 약간의 달콤함을 주는 쿠키 이름의 유래이기도 합니다. 요약하자면, 세션은 사용자의 상태를 추적하기 위해 서버에 저장되는 데이터 구조입니다. 이 데이터는 클러스터, 데이터베이스 및 파일에 저장될 수 있습니다. 쿠키는 클라이언트가 사용자 정보를 저장하는 메커니즘이며 일부를 기록하는 데 사용됩니다. 사용자 정보는 Session을 구현하는 방법이기도 합니다.

4. 웹 저장소

웹 저장소는 클라이언트에 데이터를 저장하는 새로운 방법입니다. HTML5는 localStorage와 sessionStorage의 두 가지 유형이 있으며 이를 사용하여 데이터베이스를 만들 수 있습니다. 서버 측 데이터베이스의 콘텐츠를 클라이언트에 로컬로 직접 저장할 수 있으므로 서버의 부담이 크게 줄어들고 데이터 액세스 속도가 빨라집니다.

1. localStorage: 데이터가 영구적으로 저장됩니다. 클라이언트의 로컬 하드웨어 장치(하드 디스크 또는 기타 하드웨어 장치)에 데이터를 저장하면 브라우저를 닫아도 데이터는 그대로 유지됩니다. localStorage의 범위는 문서 소스 수준으로 제한됩니다. 서로 다른 문서 소스는 서로의 데이터를 읽고 수정할 수 없지만 동일한 문서 소스는 가능합니다. 그러나 서로 다른 브라우저는 저장소를 공유하지 않습니다. 즉, 동일한 문서 소스라 할지라도 Chrome 브라우저에 저장한 데이터는 Firefox에서 액세스할 수 없습니다.
2. sessionStorage: 데이터를 임시 저장합니다. 데이터는 세션 개체에 저장됩니다. 저장시간은 웹페이지 진입부터 브라우저 웹페이지 종료까지의 시간입니다. sessionStorage의 범위도 문서 소스 수준으로 제한되며, 다른 탭의 동일한 페이지에도 자체 sessionStorage가 있으며 데이터를 공유할 수 없습니다. 페이지에 두 개의 iframe 요소가 있는 경우 sessionStorage를 공유합니다.

위 내용은 쿠키, 세션, 저장 기능 요약의 상세 내용입니다. 자세한 내용은 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를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

쿠키는 어디에 저장되나요? 쿠키는 어디에 저장되나요? Dec 20, 2023 pm 03:07 PM

쿠키는 일반적으로 브라우저의 쿠키 폴더에 저장되며, 브라우저의 쿠키 파일은 일반적으로 바이너리 또는 SQLite 형식으로 저장됩니다. 쿠키 파일을 직접 열면 일부 왜곡되거나 읽을 수 없는 내용이 나타날 수 있으므로 사용하는 것이 가장 좋습니다. 쿠키를 보고 관리하기 위해 귀하의 브라우저에서 제공하는 쿠키 관리 인터페이스.

컴퓨터의 쿠키는 어디에 있습니까? 컴퓨터의 쿠키는 어디에 있습니까? Dec 22, 2023 pm 03:46 PM

컴퓨터의 쿠키는 사용된 브라우저 및 운영 체제에 따라 브라우저의 특정 위치에 저장됩니다. 1. Google Chrome, C:\Users\YourUsername\AppData\Local\Google\Chrome\User Data\Default\Cookies에 저장됨 등.

세션 실패를 해결하는 방법 세션 실패를 해결하는 방법 Oct 18, 2023 pm 05:19 PM

세션 실패는 일반적으로 세션 수명 만료 또는 서버 종료로 인해 발생합니다. 해결 방법은 다음과 같습니다. 1. 세션 수명을 연장합니다. 3. 쿠키를 사용합니다. 4. 세션 관리 미들웨어를 사용합니다.

PHP 세션 교차 도메인 문제에 대한 솔루션 PHP 세션 교차 도메인 문제에 대한 솔루션 Oct 12, 2023 pm 03:00 PM

PHPSession의 도메인 간 문제 해결 프런트엔드와 백엔드 분리 개발에서 도메인 간 요청이 표준이 되었습니다. 도메인 간 문제를 처리할 때 일반적으로 세션 사용 및 관리가 포함됩니다. 그러나 브라우저 원본 정책 제한으로 인해 기본적으로 도메인 간에 세션을 공유할 수 없습니다. 이 문제를 해결하려면 도메인 간 세션 공유를 달성하기 위한 몇 가지 기술과 방법을 사용해야 합니다. 1. 도메인 간 세션을 공유하기 위한 쿠키의 가장 일반적인 사용

모바일 쿠키는 어디에 있나요? 모바일 쿠키는 어디에 있나요? Dec 22, 2023 pm 03:40 PM

휴대폰의 쿠키는 모바일 장치의 브라우저 애플리케이션에 저장됩니다. 1. iOS 장치의 경우 쿠키는 Safari 브라우저의 설정 -> Safari -> 고급 -> 웹사이트 데이터에 저장됩니다. 2. Android 장치의 경우 쿠키가 저장됩니다. 설정 -> 사이트 설정 -> 크롬 브라우저의 쿠키 등에서

쿠키 작동 방식 쿠키 작동 방식 Sep 20, 2023 pm 05:57 PM

쿠키의 작동 원리에는 쿠키를 보내는 서버, 쿠키를 저장하는 브라우저, 쿠키를 처리하고 저장하는 브라우저가 포함됩니다. 자세한 소개: 1. 서버는 쿠키를 보내고, 서버는 쿠키가 포함된 HTTP 응답 헤더를 브라우저에 보냅니다. 2. 브라우저는 쿠키 등을 저장합니다.

브라우저 쿠키가 저장되는 위치에 대한 자세한 설명 브라우저 쿠키가 저장되는 위치에 대한 자세한 설명 Jan 19, 2024 am 09:15 AM

인터넷의 대중화로 인해 우리는 브라우저를 사용하여 인터넷 서핑을 하는 것이 생활 방식이 되었습니다. 브라우저를 일상적으로 사용하다 보면 온라인 쇼핑, 소셜 네트워킹, 이메일 등 계정 비밀번호를 입력해야 하는 상황에 자주 직면하게 됩니다. 이 정보는 다음에 방문할 때 다시 입력할 필요가 없도록 브라우저에 기록되어야 합니다. 이때 쿠키가 유용합니다. 쿠키란 무엇입니까? 쿠키는 서버가 사용자의 브라우저에 전송하고 로컬에 저장되는 작은 데이터 파일을 말하며 일부 웹사이트의 사용자 행동을 포함합니다.

쿠키를 지우면 영향이 있나요? 쿠키를 지우면 영향이 있나요? Sep 20, 2023 pm 06:01 PM

쿠키 삭제의 영향에는 개인화 설정 및 기본 설정 재설정, 광고 경험 영향, 로그인 상태 및 비밀번호 기억 기능 파괴 등이 포함됩니다. 자세한 소개: 1. 개인 설정 및 기본 설정을 재설정합니다. 쿠키가 삭제되면 장바구니가 비워지고 제품을 다시 추가해야 합니다. 쿠키를 삭제하면 소셜 미디어 플랫폼의 로그인 상태도 손실되므로 필요합니다. 2. 쿠키가 삭제되면 웹사이트는 당사의 관심사와 선호도를 이해할 수 없으며 관련 없는 광고 등을 표시하게 됩니다.

See all articles