>  기사  >  웹 프론트엔드  >  Javascript에서 document.cookie 사용에 대한 자세한 소개

Javascript에서 document.cookie 사용에 대한 자세한 소개

黄舟
黄舟원래의
2017-03-22 14:35:301201검색

본 글에서는 Javascript에서의 document.cookie 사용법을 주로 소개하며, 쿠키를 통한 비밀번호 기억 및 비밀번호 저장 기능은

쿠키 설정

각 쿠키는 이름/값 쌍입니다. 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%20love%20ajax";

escape() 인코딩을 사용하는 경우 추출 후 unescape()를 사용해야 합니다. 이전에 소개된 원래 쿠키 값은 디코딩을 통해서만 얻을 수 있습니다. document.cookie는 속성처럼 보이지만 다른 값이 할당될 수 있습니다. 그러나 일반적인 속성과는 다릅니다. 할당을 변경한다고 해서 원래 값이 손실되는 것은 아닙니다. 예를 들어 다음 두 문을 계속 실행하면

document.cookie="userId=828";
document.cookie="userName=hulk";

이 때 브라우저는 userId라는 두 개의 쿠키를 유지합니다. 및 userName이므로 document.cookie에 값을 할당하는 것은 다음과 같은 명령문을 실행하는 것과 더 유사합니다.

document.addCookie("userId=828");
document.addCookie("userName=hulk");

사실 브라우저는 쿠키 값을 변경하려는 경우 다음과 같이 쿠키를 설정합니다. 값을 다시 할당합니다. 예:

document.cookie="userId=929";

이렇게 하면 userId라는 쿠키 값이 929로 설정됩니다.

쿠키 값 가져오기

다음은 쿠키 값을 가져오는 방법을 설명합니다. 쿠키 값은 document.cookie에서 직접 얻을 수 있습니다.

var strCookie=document.cookie;

이렇게 하면 세미콜론으로 구분된 여러 이름/값 쌍으로 구성된 문자열을 얻을 수 있습니다. 이러한 이름/값 쌍에는 도메인 이름 아래의 이름이 포함됩니다. 모든 쿠키. 예를 들면 다음과 같습니다.

모든 쿠키 값을 한 번만 얻을 수 있음을 알 수 있는데, 쿠키 이름을 지정하여 지정된 값을 얻을 수는 없습니다. 이것이 쿠키 처리에서 가장 번거로운 부분입니다. 가치.

지정된 쿠키 값을 얻으려면 사용자가 이 문자열을 직접 분석해야 합니다. 예를 들어 userId 값을 얻으려면 다음을 수행할 수 있습니다.

이런 방식으로 단일 쿠키

비슷한 방법을 사용하면 하나 이상의 쿠키 값을 얻을 수 있습니다. 주요 기술은 여전히 ​​문자열과 배열의 관련 작업입니다.

쿠키의 만료 날짜를 설정하세요. 지금까지 모든 쿠키는 단일 세션 쿠키였습니다. 즉, 이러한 쿠키는 브라우저를 닫은 후에 손실됩니다. 해당 하드 디스크 파일을 설정합니다.

실제 개발에서는 사용자의 로그인 상태를 저장하는 등 쿠키를 장기간 저장해야 하는 경우가 많습니다. 이는 다음 옵션을 사용하여 달성할 수 있습니다.

document.cookie="userId=828;
expires=GMT_String";

여기서 GMT_String은 GMT 형식으로 표현된 시간 문자열입니다. 이 명령문은 userId 쿠키를 GMT_String으로 표시되는 만료 시간으로 설정합니다. 접근할 수 없습니다. 예:

쿠키가 10일 후에 만료되도록 설정하려면 다음과 같이 할 수 있습니다.

<script language="JavaScript" type="text/javascript">
<!-- //获取当前时间
var date=new Date();
var expireDays=10; //将date设置为10天以后的时间
date.setTime(date.getTime()+expireDays*24*3600*1000); //将userId和userName两个cookie设置为10天后过期
document.cookie="userId=828; userName=hulk;
expire="+date.toGMTString(); //-->
</script>

쿠키 삭제

쿠키를 삭제하려면 만료 시간을 과거 시간으로 설정할 수 있습니다. 예:

<script language="JavaScript" type="text/javascript">
<!--
//获取当前时间
var date=new Date();
//将date设置为过去的时间
date.setTime(date.getTime()-10000);
//将userId这个cookie删除
document.cookie="userId=828; expire="+date.toGMTString();
//-->
</script>

기본적으로 쿠키에 액세스할 경로를 지정합니다. 페이지에 생성된 페이지는

이 쿠키는 디렉토리의 다른 페이지에서도 액세스할 수 있습니다. 이 디렉터리 아래에 하위 디렉터리가 있으면 하위 디렉터리에서도 액세스할 수 있습니다.

쿠키가 액세스할 수 있는 디렉터리를 제어하려면 경로 매개변수를 사용하여 쿠키를 설정해야 합니다. 구문은 다음과 같습니다.


document.cookie="name=value; path=cookieDir";

여기서 cookieDir은 쿠키가 있는 디렉터리를 나타냅니다. 쿠키에 접근할 수 있습니다. 예를 들어

document.cookie="userId=320; path=/shop";

는 현재 쿠키가 상점 디렉토리에서만 사용될 수 있음을 의미합니다.

웹사이트 전체에서 쿠키를 사용할 수 있게 하려면 cookie_dir을 루트 디렉터리로 지정할 수 있습니다. 예:

document.cookie="userId=320; path=/";

쿠키에 액세스할 수 있는 호스트 이름과 경로를 지정합니다. 이름은 동일한 도메인을 나타냅니다. 예를 들어 www.google.com과 gmail.google.com

은 서로 다른 호스트 이름입니다. 기본적으로 한 호스트에서 생성된 쿠키는 다른 호스트에서 액세스할 수 없지만 도메인 매개변수를 통해 제어할 수 있습니다. 구문 형식은 다음과 같습니다.

document.cookie="name=value;
domain=cookieDomain";

Google을 예로 들면, 호스트 간 액세스를 달성하려면, 다음과 같이 쓸 수 있습니다:

document.cookie="name=value;
domain=.google.com";

이렇게 하면 google.com 아래의 모든 호스트가 쿠키에 액세스할 수 있습니다.

종합적인 예: 범용 쿠키 처리 기능 구축 쿠키 처리 프로세스는 비교적 복잡하며 특정 유사점을 가지고 있습니다. 따라서 쿠키의 일반적인

작업을 완료하여 코드 재사용을 달성하기 위해 여러 기능을 정의할 수 있습니다. 일반적으로 사용되는 쿠키 작업과 해당 기능 구현은 다음과 같습니다.

1.添加一个cookie:addCookie(name,value,expireHours) 该函数接收3个参数:cookie名称,cookie值,以及在多少小时后过期。

这里约定expireHours为0时不设定过期时间,即当浏览器关闭时cookie自动消失。该函数实现如下:

<script language="JavaScript" type="text/javascript">
<!--
function addCookie(name,value,expireHours){
       var cookieString=name+"="+escape(value);
       //判断是否设置过期时间
       if(expireHours>0){
          var date=new Date();
          date.setTime(date.getTime+expireHours*3600*1000);
          cookieString=cookieString+"; expire="+date.toGMTString();
       }
       document.cookie=cookieString;
}
//-->
</script>

2.获取指定名称的cookie值:getCookie(name)

该函数返回名称为name的cookie值,如果不存在则返回空,其实现如下:

<script language="JavaScript" type="text/javascript">
<!--
function getCookie(name){
       var strCookie=document.cookie;
       var arrCookie=strCookie.split("; ");
       for(var i=0;i<arrCookie.length;i++){
          var arr=arrCookie[i].split("=");
          if(arr[0]==name)return arr[1];
       }
       return "";
}
//-->
</script>

3.删除指定名称的cookie:deleteCookie(name)

该函数可以删除指定名称的cookie,其实现如下:

<script language="JavaScript" type="text/javascript">
<!--
function deleteCookie(name){
       var date=new Date();
       date.setTime(date.getTime()-10000);
       document.cookie=name+"=v; expire="+date.toGMTString();
}
//-->
</script>

위 내용은 Javascript에서 document.cookie 사용에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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