ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • 자바스크립트와 쿠키(cookie) 사용법
    컴퓨터 2008. 3. 7. 20:03

    자바스크립트 쿠키는 CGI의 HTTP Cookie와 내용 및 작동하는 법은 같으나 약간의 차이가 있습니다. 아래는 자바스크립트 쿠키에 대한 개요입니다.

    1. 자바스크립트에서 지원하는 사용자의 특정 정보를 저장하는 기법
    2. 클라이언트의 브라우저에 저장되나 서버에는 저장되지 않습니다.
    3. 일정 기간 동안만 유효하게 할 수 있고, 유효기간(만료기한)이 설정되지 않을 경우 브라우저 종료시 자동으로 사라집니다.
    4. 클라이언트에는 브라우저가 실행중에는 메모리에, 종료될 경우 만료기한에 따라 cookies.txt라는 파일에 저장될 수 있습니다.
    5. 웹 서버의 환경변수 HTTP_COOKIE에는 저장되지 않습니다.

    자바스크립트 쿠키는 서버와는 무관하기 때문에 일반적으로 잘 사용하지는 않습니다. 그러나, 클라이언트 내에서는 얼마든지 쿠키의 정보유지기법을 사용할 수 있으므로 간단한 방문 기록 남기기 등에서는 쓰일 수 있습니다.

    자바스크립트에서 쿠키를 참조하기 위해서는 document.cookie객체를 사용합니다. 아래는 가장 일반적으로 사용되는 쿠키 관련 자바스크립트 함수들입니다. 아래 함수의 주요 기능은 document.cookie객체의 문자열 조작을 통하여 쿠키로부터 값을 빼내는데 사용됩니다.

    function getCookieVal (offset) {
       var endstr = document.cookie.indexOf (";", offset);
       if (endstr == -1) endstr = document.cookie.length;
       return unescape(document.cookie.substring(offset, endstr));
    }

    function GetCookie (name) {
       var arg = name + "=";
       var alen = arg.length;
       var clen = document.cookie.length;
       var i = 0;
       while (i < clen) { //while open
          var j = i + alen;
          if (document.cookie.substring(i, j) == arg)
             return getCookieVal (j);
          i = document.cookie.indexOf(" ", i) + 1;
          if (i == 0) break;
       } //while close
       return null;
    }

    function SetCookie (name, value) {
       var argv = SetCookie.arguments;
       var argc = SetCookie.arguments.length;
       var expires = (2 < argc) ? argv[2] : null;
       var path = (3 < argc) ? argv[3] : null;
       var domain = (4 < argc) ? argv[4] : null;
       var secure = (5 < argc) ? argv[5] : false;
       document.cookie = name + "=" + escape (value) +
          ((expires == null) ? "" :
             ("; expires=" + expires.toGMTString())) +
          ((path == null) ? "" : ("; path=" + path)) +
          ((domain == null) ? "" : ("; domain=" + domain)) +
          ((secure == true) ? "; secure" : "");
    }

    위의 함수에서 사용자가 쓸 함수는 GetCookie(), SetCookie()입니다. 사용하는 문법은 아래와 같습니다.

    * GetCookie
    설정되어 있는 쿠키의 값을 가져옵니다.

    쿠키값 = GetCookie(name)

    인수 설명)
    name(필수 요소)
    저장된 Cookie의 이름
     
    예)
    cookieval = GetCookie('myCookie');

    * SetCookie
    쿠키의 값을 설정한다.

    SetCookie(name, value, [expires], [path], [domain], [secure])

    인수 설명)
    name(필수 요소)
    Cookie에 저장하고자 하는 이름
    value(필수 요소)
    Cookie에 저장된 이름(name)에 대한 값
    expires(생략 가능)
    Cookie가 설정된 후 Cookie가 무효화되는 시간이다.
    (GMT Type - "Wdy, DD-Mon-YYYY HH:MM:SS GMT")
    설정된 시간이 지나게 되면, 이 Cookie는 사용할 수 없게 된다.
    만약 expires에 설정된 시간보다 더 일찍 브라우저가 종료될 경우, 브라우저는 자동으로
    cookies.txt라는 파일을 생성하여 그 정보를 이 파일에 저장해 둡니다.

    Netscape 4.x의 경우)
    C:\Program Files\Netscape\Users\[Profile name]\cookies.txt
    Internet Explorer 4.x의 경우)
    C:\windows\Cookies\[remote user name]@[domain].txt


    path(생략 가능)
    문서의 경로명을 설정합니다.
    설정하지 않으면 현재 Cookie를 보내는 문서의 URL상의 경로(도메인 명 제외)로 설정됩니다.
    domain(생략 가능)
    웹 서버의 도메인 명을 설정합니다.
    설정하지 않으면 현재 Cookie를 보내는 문서가 속한 도메인 명으로 설정됩니다.
    secure(생략 가능)
    HTTPS Server(HTTP over SSL)와 같은 Secure Server에서 Cookie를 보낼 경우 이 값을 설정해 줍니다.
     
    예 1)
    쿠키값만 설정할 경우
    SetCookie('myCookie', 1234); 

    예 2)
    쿠키값 및 만료일을 설정할 경우
    var ExpDate = new Date();
    ExpDate.setTime(ExpDate.getTime() + 1000*60*60*24);
    SetCookie('myCookie', 1234, ExpDate);

    ※ 위의 예제는 만료일을 쿠키가 생성되는 현재 시간 + 1일로 설정합니다.
    만약, 만료일을 쿠키가 생성된 후 1시간으로 설정하겠다면 위의 예제에서 24(시간)를
    1(시간) 로 바꾸어 주면 됩니다.


    아래의 예제는 쿠키값을 설정하고, 만료일을 쿠키가 설정된 후 1시간 이후로 설정하는
    예제입니다.

    <html>
    <head>
    <title>JavaScript Cookie Test</title>
    <script language=javascript>
    <!--
    var ExpDate = new Date();

    function getCookieVal (offset) {
       var endstr = document.cookie.indexOf (";", offset);
       if (endstr == -1) endstr = document.cookie.length;
       return unescape(document.cookie.substring(offset, endstr));
    }

    function GetCookie (name) {
       var arg = name + "=";
       var alen = arg.length;
       var clen = document.cookie.length;
       var i = 0;
       while (i < clen) { //while open
          var j = i + alen;
          if (document.cookie.substring(i, j) == arg)
             return getCookieVal (j);
          i = document.cookie.indexOf(" ", i) + 1;
          if (i == 0) break;
       } //while close
     return null;
    }

    function SetCookie (name, value) {
       var argv = SetCookie.arguments;
       var argc = SetCookie.arguments.length;
       var expires = (2 < argc) ? argv[2] : null;
       var path = (3 < argc) ? argv[3] : null;
       var domain = (4 < argc) ? argv[4] : null;
       var secure = (5 < argc) ? argv[5] : false;
       document.cookie = name + "=" + escape (value) +
          ((expires == null) ? "" : ("; expires=" + expires.toGMTString())) +
          ((path == null) ? "" : ("; path=" + path)) +
          ((domain == null) ? "" : ("; domain=" + domain)) +
          ((secure == true) ? "; secure" : "");
    }

    function SetCookieVal () {
       pathname = location.pathname;
       var myDomain = pathname.substring(0, pathname.lastIndexOf('/')) +'/';
       ExpDate.setTime(ExpDate.getTime() + 1000*60*60);
       SetCookie('MyCookie', 'Hello Cookie!', ExpDate, myDomain);
    }
    //-->
    </script>
    <body>
    <script language=javascript>
    <!--
       if(GetCookie('MyCookie')) {
          alert("Cookie Found");
          document.write(GetCookie('MyCookie') + '<br>');
       }
       else {
          SetCookieVal();
          document.write('새로운 쿠키값이 설정되었습니다. ');
          document.write('보고 싶으시면 Reload를 누르세요.<br>');
          document.write('이 쿠키는 ' + ExpDate.toString());
          document.write(' 에 자동 폭파됩니다.<br>');
       }
    //-->
    </script>
    </body>
    </html>

    쿠키는 설정된 후에 브라우저가 활성화 되어 있고 만료일이 경과되지 않는 한 브라우저에 따라 설정된 디렉토리 내의 cookies.txt를 지우더라도 값이 유지된다는 점을 주의하기 바랍니다.

Designed by Tistory.