Posted on 2008/03/10 20:41
Filed Under Web(웹) Study/Java Script

자바스크립트 쿠키는 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를 지우더라도 값이 유지된다는 점을 주의하기 바랍니다.

크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)
2008/03/10 20:41 2008/03/10 20:41

트랙백 주소 : http://skystory.kr/trackback/189

댓글을 달아 주세요

  1. 이현 2010/04/24 00:08  댓글주소  수정/삭제  댓글쓰기

    안녕하세요 주인장님 글 감사합니다
    보다가 갑작스럽게 생각난것이 있어서 여쭤봅니다
    어떤 블로그를 들어가보니 한이미지가 나왔다가
    다시 껏다가 들어가보니 그이미지가 사라졌습니다 하루내내 보이지않다가
    나중에 들어가보니또있는데 다시 들어가보니 그 이미지가 없거나
    딴이미지가 뜹니다. 이게 다른분은 쿠키사용법이라고 하는데 도저히방법을 모르겠습니다 너무 궁금해서 제 블로그에서도 한번해보고싶은데..
    저는 기본적인 html 밖에 몰라서요 혹시아시나요 ?

    • 하늘이야기 2010/05/03 13:48  댓글주소  수정/삭제

      답변이 늦었네요~

      그 부분은 아마도 랜덤 이미지 출력 되는 부분인듯 합니다.
      "자.스"로도 가능하지만 보통 프로그램으로 램던함 이름값을 던저서 이미지를 불러 오는 방식을 사용하는듯 합니다.

      그 부분은 PHP나 ASP등등 웹언어에서 개발된 것들이 많으며 찾으시면 쉽게 검색이 됩니다...

[로그인][오픈아이디란?]

About

by 하늘이야기

Archive

Counter

· Total
: 1039977
· Today
: 288
· Yesterday
: 588
-->