<head>
<script language="javascript">
function GetCookie(name){
var arg = name + "="; // arg 선언동시에 "name="를받아 대입.
var alen = arg.length;// arg변수의 길이
var clen = document.cookie.length; //총 쿠키의 길이
var i = 0;
while(i < clen){ //0부터 총쿠키의 길이 까지 반복문 돌림.
var j = i + alen; //j 변수선언과 동시에 0 + arg변수의 길이를 합한 값을 대입.
//j는 나중에 시작지점이 중간지점부터 되게하려고 선언되어 졌다. (getCookieValue()때)
if(document.cookie.substring(i, j) == arg){ //0번째 인덱스부터 0+arg길이까지 문자열을 가져올때 arg와 동일하다면,
// 즉, 쿠키값이 하나이상이 있다면, (하나이상이 있는지는 getCookieValue()함수로 파악)
//substr()을 쓴다면 0번째 인덱스부터 0+alen개의 문자열을 가져올때 처럼 해석됨.
return getCookieVal(j); // getCookieVal()함수 호출하여 그 함수에대한 return값을 반환.
}else{ // 0번째 인덱스부터 0+alen번째 인덱스값까지 문자열을 가져올때 arg와 다르다면,
// 즉, 쿠키값이 하나도 없다면,
i = document.cookie.indexOf(" ", i) + 1; // 0번째 인덱스부터(즉, 맨처음부터) 공백인 문자열을 찾아 파싱한 값+1 을 i에다 재선언함
//여기서 공백인 문자열을 못찾는다면,
}if(i == 0) break; // break걸려,
}return null; // 최종적으로, null값 반환.
}function SetCookie(name, value){
var argv = SetCookie.arguments; // argv변수는 SetCookie()함수의 파라미터 정보의 배열을 가짐.
// argv[0]은 첫 번째 파라미터를 의미함
var argc = SetCookie.arguments.length; //argc변수는 파라미터 개수를 가짐
var expires = (argc > 2) ? argv[2] : null; // 논리연산자를 이용하여 파라미터 값을 넣을지 null값을 넣을지 결정
var path = (argc > 3) ? argv[3] : null;
var domain = (argc > 4) ? argv[4] : null;
var secure = (argc > 5) ? argv[5] : false;
document.cookie = name + "=" + encodeURI(value) + //전달된 값을 연결하여 쿠키형식의 문자열을 만들어
((expires == null) ? "" : ("; expires=" + expires.toUTCString())) + // 최종적인 문자열이
((path == null) ? "" : ("; path=" + path)) + // document.cookie에 저장되어
((domain == null) ? "" : ("; domain=" + domain)) + //새로운 쿠키가 생성
((secure == true) ? "; secure" : "");
}function DeleteCookie(name) {
var exp = new Date();
exp.setTime(exp.getTime() - 1);
var cval = GetCookie(name);
document.cookie = name + "=" + cval + "; expires=" + exp.toUTCString();
}
var exp = new Date(); //Date()함수를 선언하여 exp에 대입 (쿠키의 자동삭제기간을 생성하기 위함)
exp.setTime(exp.getTime() + (24*60*60*1000)); //setTime()에서는 밀리초단위를 1로 둔다 즉, 1= 0.001초 1000=1초;1분*60=1시간*24=하루
function amt(){ //방문 횟수 출력 main함수
var count = GetCookie('count'); //count에 getcookie()함수 대입.
if(count == null){ // 누적되있는 cookie값이 없다면 == (정수로 1 도 없다면)
SetCookie('count','1'); //SetCookie()에 getCookie(1)과 value 1을 넣음.
return 1; //그후 1을 반환.
}else{ //누적되있는 cookie값이 있다면 == (정수로 1 이상이 있다면)
var newcount = parseInt(count) + 1; //GetCookie('count')에 저장되있는 문자열을 10진수화하여 + 1 하여 newcount 재선언.
DeleteCookie('count'); //현재 가지고 있는 GetCookie('count') 값 삭제
SetCookie('count', newcount, exp); //다시 GetCookie('count')에 +1누적되있는 값과 자동삭제날짜를 넣어 SetCookie시키고,
return count; // 현 count를 정수로 반환 (즉, 예전 count+1를 반환)
}
}function getCookieVal(offset){ //GetCookie()함수에서 j파라미터값을 받아,
var endstr = document.cookie.indexOf(";", offset); // cookie내에서 offset(시작지점)부터 시작하여 ;를 파싱 한다
if (endstr == "-1"){//cookie에서의 offset지점부터 문자열 ;를 파싱하지 못한다면
//GetCookie()함수에서 하지못한 총쿠키길이 파악.
endstr = document.cookie.length; //endstr는 총 쿠키길이가 되고
return decodeURI(document.cookie.substring(offset, endstr));
// offset시작지점부터 총길이의 endstr갯수(총쿠키길이) 만큼 문자열을 잘라 count로 디코딩함
}}
</script>
<body>
<script language="javascript">
document.write("당신은 <font Color=red><b>" + amt() + "</b></font> 째 방문객입니다.");
</script>
</body>