쿠키 개요
이전 섹션에서는 쇼핑 열 데이터를 저장하는 데 불변 프레임워크가 사용되었으며, 제품 표시 페이지는 지속적으로 변경되었지만 이는 시뮬레이션된 전역 변수를 달성할 수 있었습니다. , 그러나 엄격하지는 않습니다. 예를 들어 탐색 프레임 페이지 내에서 마우스 오른쪽 버튼을 클릭하고 바로 가기 메뉴에서 [새로 고침] 명령을 클릭하면 모든 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%"로 인코딩되며 이 솔루션을 사용하면 또한 중국어 왜곡 문자의 출현을 피하십시오. 예: