js_javascript 기술의 쿠키 사용에 대한 자세한 분석
쿠키 개요
이전 섹션에서는 쇼핑 열 데이터를 저장하는 데 불변 프레임워크가 사용되었으며, 제품 표시 페이지는 지속적으로 변경되었지만 이는 시뮬레이션된 전역 변수를 달성할 수 있었습니다. , 그러나 엄격하지는 않습니다. 예를 들어 탐색 프레임 페이지 내에서 마우스 오른쪽 버튼을 클릭하고 바로 가기 메뉴에서 [새로 고침] 명령을 클릭하면 모든 JavaScript 변수가 손실됩니다. 따라서 엄격한 페이지 간 전역 변수를 구현하려면 이 방법을 사용할 수 없습니다. JavaScript의 또 다른 메커니즘: 쿠키는 실제 전역 변수의 요구 사항을 충족할 수 있습니다.
쿠키는 브라우저에서 제공하는 메커니즘으로, 문서 개체의 쿠키 속성을 JavaScript에 제공합니다. JavaScript로 제어할 수 있으며 JavaScript 자체의 속성은 아닙니다. 쿠키는 사용자의 하드 드라이브에 저장된 파일로, 일반적으로 브라우저가 해당 도메인 이름에 다시 액세스하면 쿠키를 사용할 수 있게 됩니다. 따라서 쿠키는 하나의 도메인 이름 아래 여러 웹 페이지에 걸쳐 있을 수 있지만 여러 도메인 이름에 걸쳐 사용할 수는 없습니다.
브라우저마다 쿠키를 다르게 구현하지만 해당 속성은 동일합니다. 예를 들어 Windows 2000 및 Windows XP에서는 쿠키 파일이 document 및 settingsuserNamecookie 폴더에 저장됩니다. 일반적인 이름 지정 형식은 userName@domain.txt입니다.
쿠키 메커니즘은 사용자의 하드 드라이브에 정보를 저장하므로 전역 변수로 사용할 수 있다는 것이 가장 큰 장점 중 하나입니다. 다음과 같은 상황에서 사용할 수 있습니다.
(1) 사용자 로그인 상태를 저장합니다. 예를 들어, 사용자 ID는 쿠키에 저장되므로 사용자가 다음에 해당 페이지를 방문할 때 다시 로그인할 필요가 없습니다. 현재 많은 포럼과 커뮤니티에서 이 기능을 제공하고 있습니다. 쿠키는 만료 시간을 설정할 수도 있습니다. 제한 시간이 만료되면 쿠키는 자동으로 사라집니다. 따라서 시스템은 종종 사용자에게 로그인 상태를 유지하라는 메시지를 표시할 수 있습니다. 일반적인 옵션은 1개월, 3개월, 1년 등입니다.
(2) 사용자 행동을 추적합니다. 예를 들어, 일기예보 웹사이트는 사용자가 선택한 지역을 기반으로 현지 기상 조건을 표시할 수 있습니다. 매번 위치를 선택해야 한다면 번거로울 수 있지만, 쿠키를 사용하면 시스템이 마지막으로 방문한 지역을 기억하여 다음에 해당 페이지를 열 때 자동으로 표시됩니다. 해당 지역의 마지막 사용자. 모든 것이 백그라운드에서 이루어지기 때문에 이러한 페이지는 마치 특정 사용자를 위해 맞춤화된 것처럼 사용하기 매우 편리합니다.
(3) 맞춤형 페이지. 웹사이트가 스킨 변경이나 레이아웃 변경 기능을 제공하는 경우 배경색상, 해상도 등 이용자의 선택사항을 기록하기 위해 쿠키를 사용할 수 있습니다. 사용자가 다음에 방문할 때 마지막 방문의 인터페이스 스타일이 계속 저장될 수 있습니다.
(4) 장바구니를 만듭니다. 이전 예시와 마찬가지로 쿠키는 사용자가 구매해야 하는 품목을 기록하는 데 사용되며, 결제 시 균일하게 제출될 수 있습니다. 예를 들어, Taobao는 쿠키를 사용하여 사용자가 탐색한 제품을 기록하고 언제든지 비교할 수 있도록 합니다.
물론 위 애플리케이션은 쿠키가 완성할 수 있는 애플리케이션 중 일부일 뿐이며, 전역 변수를 필요로 하는 기능이 더 많이 있습니다. 쿠키의 단점은 주로 보안 및 개인 정보 보호에 중점을 둡니다. 주로 다음 유형을 포함합니다.
(1) 쿠키가 비활성화될 수 있습니다. 사용자가 개인정보 보호에 많은 관심을 기울이면 브라우저의 쿠키 기능이 비활성화될 가능성이 높습니다.
(2) 쿠키는 브라우저와 관련이 있습니다. 이는 동일한 페이지를 방문하더라도 서로 다른 브라우저에 저장된 쿠키에 서로 접근할 수 없음을 의미합니다.
(3) 쿠키가 삭제될 수 있습니다. 각 쿠키는 하드 디스크에 있는 파일이기 때문에 사용자가 삭제할 가능성이 높습니다.
(4) 쿠키 보안이 충분히 높지 않습니다. 모든 쿠키는 일반 텍스트 형태로 파일에 기록되므로, 사용자 이름, 비밀번호, 기타 정보를 저장하려면 미리 암호화해 두는 것이 가장 좋습니다.
쿠키 설정
각 쿠키는 이름/값 쌍입니다. document.cookie에 다음 문자열을 할당할 수 있습니다.
document.cookie ="userId= 828";
한 번에 여러 이름/값 쌍을 저장하려면 세미콜론과 공백(;)을 사용하여 구분할 수 있습니다. 예:
document.cookie="userId=828 ; userName=hulk";
쿠키 이름이나 값에는 세미콜론(;), 쉼표(,), 등호(=) 및 공백을 사용할 수 없습니다. 쿠키 이름으로 하면 쉽지만, 저장되는 값은 정의되어 있지 않습니다. 이 값을 저장하는 방법은 무엇입니까? 방법은 escape() 함수를 사용하여 일부 특수 기호의 16진수 표현을 사용할 수 있는 인코딩을 사용하는 것입니다. 예를 들어 공백은 쿠키 값에 저장될 수 있는 "20%"로 인코딩되며 이 솔루션을 사용하면 또한 중국어 왜곡 문자의 출현을 피하십시오. 예:
document.cookie ="str= " escape("I love ajax");
은 다음과 동일합니다:
document.cookie="str=I love ajax";
escape() 인코딩을 사용할 경우 앞서 소개한 원래 쿠키 값을 얻기 위해서는 값을 빼낸 후 unescape()를 사용하여 디코딩해야 합니다.
document.cookie는 속성처럼 보이고 다른 값이 할당될 수 있지만. 하지만 일반 속성과는 다릅니다. 할당을 변경한다고 해서 원래 값이 손실되는 것은 아닙니다. 예를 들어 다음 두 문을 계속 실행하면 됩니다.
document.cookie="userId=828";
document.cookie="userName=hulk"
이때 브라우저는 userId와 userName이라는 두 개의 쿠키를 유지 관리하므로 document.cookie에 값을 할당하는 것은 다음과 같은 문을 실행하는 것과 비슷합니다.
document.addCookie("userId=828")
document.addCookie( "userName=hulk"); 실제로 브라우저는 쿠키를 이런 방식으로 설정합니다. 예를 들면 다음과 같습니다.
userId라는 쿠키 값을 929로 설정합니다.
쿠키 값 가져오기
다음은 쿠키 값을 가져오는 방법을 설명합니다. 쿠키 값은 document.cookie에서 직접 얻을 수 있습니다.
var strCookie=document.cookie;
이렇게 하면 세미콜론으로 구분된 여러 이름/값 쌍으로 구성된 문자열이 생성됩니다. 이 도메인 이름 아래의 모든 쿠키를 포함합니다. 예:
출력에서 볼 수 있듯이 모든 쿠키 값은 한 번에 얻을 수 있지만 쿠키 이름을 지정하여 지정된 값을 얻으려면 쿠키 값을 처리하는 것이 가장 까다로운 부분입니다. 지정된 쿠키 값을 얻으려면 사용자가 이 문자열을 직접 분석해야 합니다. 예를 들어 userId 값을 얻으려면 다음을 수행할 수 있습니다.
이 방법으로 단일 쿠키의 값을 얻을 수 있습니다.
비슷한 방법을 사용하면 하나 이상의 쿠키 값을 얻을 수 있습니다. 주요 기술은 여전히 문자열과 배열의 관련 작업입니다.
쿠키 만료 날짜 설정
현재까지 모든 쿠키는 단일 세션 쿠키입니다. 즉, 이러한 쿠키는 브라우저를 닫으면 손실됩니다. 이러한 쿠키는 해당 하드 디스크 파일을 생성하지 않고 메모리에 저장됩니다.
실제 개발에서는 사용자의 로그인 상태를 저장하는 등 쿠키를 장기간 저장해야 하는 경우가 많습니다. 이는 다음 옵션을 사용하여 달성할 수 있습니다: document.cookie="userId=828; 만료=GMT_String";
여기서 GMT_String은 GMT 형식으로 표현된 시간 문자열입니다. 쿠키는 GMT_String으로 표시되는 만료 시간으로 설정됩니다. 이 시간이 지나면 쿠키는 사라지고 액세스할 수 없게 됩니다. 예: 쿠키가 10일 후에 만료되도록 설정하려면 다음과 같이 하면 됩니다.
코드 복사
기본적으로 특정 페이지에 쿠키가 생성되면 해당 쿠키는 해당 페이지에 있는 디렉터리의 다른 페이지에서도 접근할 수 있습니다. 페이지가 위치해 있습니다. 이 디렉터리 아래에 하위 디렉터리가 있으면 하위 디렉터리에서도 액세스할 수 있습니다. 예를 들어, www.xxxx.com/html/a.html에서 생성된 쿠키는 www.xxxx.com/html/b.html 또는 www.xxx.com/html/some/c.html에서 액세스할 수 있지만 액세스할 수는 없습니다. www.xxxx.com/d.html에서 액세스할 수 있습니다.
쿠키가 액세스할 수 있는 디렉터리를 제어하려면 path 매개변수를 사용하여 쿠키를 설정해야 합니다. 구문은 다음과 같습니다.
document.cookie="name=value; path =cookieDir";
여기서 cookieDir은 액세스 가능한 쿠키의 디렉토리를 의미합니다. 예:
document.cookie="userId=320; path=/shop";
은 현재 쿠키가 상점 디렉토리에서만 사용될 수 있음을 의미합니다.
웹사이트 전체에서 쿠키를 사용할 수 있게 하려면 cookie_dir을 루트 디렉터리로 지정할 수 있습니다. 예:
할 수 있는 호스트 이름을 지정합니다. 쿠키
document.cookie="name =value; domain=cookieDomain";
Google을 예로 들어 교차 호스트 액세스를 달성하려면 다음과 같이 작성할 수 있습니다.
document.cookie="name=value;domain=.google.com"; google.com 아래의 모든 호스트는 쿠키에 액세스할 수 있습니다.
종합적인 예: 범용 쿠키 처리 기능 구축
쿠키 처리 프로세스는 비교적 복잡하며 특정 유사점을 가지고 있습니다. 따라서 일반적인 쿠키 작업을 완료하기 위해 여러 함수를 정의하여 코드 재사용을 달성할 수 있습니다. 일반적인 쿠키 작업과 해당 기능 구현은 다음과 같습니다.
1. 쿠키 추가: addCookie(name, value,expiresHours)
이 함수는 쿠키 이름, 쿠키 값, 만료 시간 등 3가지 매개변수를 받습니다. 만료 시간이 0이면 만료 시간이 설정되지 않습니다. 즉, 브라우저를 닫으면 쿠키가 자동으로 사라집니다. 해당 기능은 다음과 같이 구현됩니다.

핫 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)

최근 많은 Windows 사용자가 Google Chrome 브라우저에서 웹사이트 URL에 액세스하는 동안 Roblox403 Forbidden Error라는 비정상적인 오류가 발생했습니다. Chrome 앱을 여러 번 다시 시작해도 아무 작업도 수행할 수 없습니다. 이 오류에는 여러 가지 잠재적인 원인이 있을 수 있으며 그 중 일부는 아래에 설명되어 있습니다. Chrome의 검색 기록 및 기타 캐시와 손상된 데이터 불안정한 인터넷 연결 잘못된 웹사이트 URL 타사 소스에서 설치된 확장 프로그램 위의 모든 측면을 고려한 후 사용자가 이 문제를 해결하는 데 도움이 될 수 있는 몇 가지 수정 사항을 찾아냈습니다. 동일한 문제가 발생하면 이 문서의 해결 방법을 확인하세요. 수정 1

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

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

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

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

쿠키 유출의 위험에는 개인 신원 정보 도용, 개인 온라인 행동 추적, 계정 도용 등이 포함됩니다. 자세한 소개: 1. 이름, 이메일 주소, 전화번호 등과 같은 개인 신원 정보가 도난당했습니다. 이 정보는 범죄자가 신원 도용 및 사기와 같은 불법 활동을 수행하는 데 사용될 수 있습니다. 범죄자는 쿠키를 통해 사용자의 검색 기록, 쇼핑 선호도, 취미 등을 알 수 있습니다. 3. 로그인 인증을 우회하고 사용자 계정에 직접 접근하는 등의 행위가 가능합니다.

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

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