JS | 쿠키(🍪cookie)

2023. 1. 5. 16:15·JavaScript

뉴진스 Cookie 🍪

쿠키와 세션 : 정보를 지속적으로 유지하기 위한 수단 

 

https://ko.javascript.info/cookie

 

쿠키와 document.cookie

 

ko.javascript.info

 

js 쿠키(🍪cookie)

 

쿠키를 문자열로 받음

 

 

 


 

예제 1 ) 🍪 Cookie의 이름과 🍪 Cookie의 값을 입력 받아 🍪 쿠키를 만들고

🍪 Cookie의 이름을 검색해서 🍪 Cookie 찾기

 

🍪

1번 html
2번 html

1번 🍴

html 

Cookie Name : <input type="text" id="cookieName">
Cookie Value : <input type="text" id="cookieValue">
<button id = "btn">쿠키 만들기</button>

script 

 //// document.cookie = "키=값";
        //// document.cookie = "키=값; expires = UTC스트링시간타입";

        //var date = new Date(); 
        //date.setMinutes(date.getMinutes()+1); //지금 시간으로부터 1분뒤
        
        //console.log(date);

        ////                        path=/; : 쿠키가 생성된 도메인 (생략가능)
        //document.cookie = "키=값; path=/; expires=UTC스트링" + date.toUTCString();


        var cookieName = document.getElementById("cookieName"); 
        var cookieValue = document.getElementById("cookieValue"); 

        var btn = document.getElementById("btn");

        

        btn.onclick = function(){

            var date = new Date();
            date.setHours(date.getHours()+1); //지금 시간으로부터 1시간 뒤

            var key = cookieName.value; //사용자가 입력한 값
            var val = cookieValue.value; //사용자가 입력한 값 

            var cookie = "";
            cookie += key + "=" + val + ";";
            cookie += " path=/;";
            cookie += " expires=" + date.toUTCString();

            document.cookie = cookie; 

            // document.cookie = "키=값; path=/; expires="+date.toUTCStrint();
        }

        //고유하게 확인할 값들을 넣어준다. 개인정보 x
        //인코딩 시켜서 넣어도 다시 디코딩 시켜서 뺄 수 있음
        //쿠키는 동일한 key가 만들어지면 덮어씌어진다. (map과 같음)

 

2번 🍴

html 

 <h3>1번 페이지에서 만든 쿠키를 사용할거야</h3>
    
    <input type="text" id="findCookie">
    <button id="btn">찾을 쿠키명</button>

script 

  // console.log(document.cookie); 
        var findCookie = document.getElementById("findCookie");
        var btn = document.getElementById("btn");
        
        btn.onclick = function(){

            //사용자가 입력한 값 
            var find = findCookie.value;

            var arr = document.cookie.split(";");
            console.log(arr); 

            //반복을 이용해서 쿠키를 찾음
            for(i in arr){ //i는 인덱스
                if(arr[i].indexOf(find) != -1){ //입력한 값이 있다면
                    //console.log('쿠키있음');
                    console.log(arr[i]);
                    var value = arr[i].replaceAll(" ","").replace(find+"=",""); //값
                    console.log("키 : " + find);
                    console.log("값 : " + value); 
                }
            }
        }

퀴즈 1 ) 팝업창 하루동안 열지 않기 🍪쿠키 만들기

popup.html
0.00MB
popup.js
0.00MB
main.html
0.00MB

 

 

'JavaScript' 카테고리의 다른 글

JS | AJAX (비동기 통신)  (0) 2023.01.06
JS | 세션(session)  (0) 2023.01.05
JS | 콜백함수 (매우중요)  (0) 2023.01.05
JS | BOM - location 객체, history 객체  (0) 2023.01.05
JS | BOM - 윈도우객체  (0) 2023.01.04
'JavaScript' 카테고리의 다른 글
  • JS | AJAX (비동기 통신)
  • JS | 세션(session)
  • JS | 콜백함수 (매우중요)
  • JS | BOM - location 객체, history 객체
개발 공부
개발 공부
  • 개발 공부
    개발 공부
    개발 공부
  • 전체
    오늘
    어제
    • 전체보기 (163)
      • 프로젝트 (1)
      • JavaScript (46)
      • Node.js (3)
      • Next.js (5)
      • React (17)
      • NoSQL (0)
      • HTML,CSS (3)
      • CS (6)
      • Java (35)
      • Spring (6)
        • Spring의 정석 (1)
      • Spring boot (1)
      • MySQL (1)
      • 리눅스 (16)
      • JSP (9)
      • AWS (0)
      • git (2)
      • 알고리즘 (1)
      • ect (7)
      • Project (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    Java의 정석
    티스토리챌린지
    Java
    자바
    자바의 정석
    오블완
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
개발 공부
JS | 쿠키(🍪cookie)
상단으로

티스토리툴바