[패스트캠퍼스python] 장고프로젝만들기 전체 순서/흐름도(ft.쇼핑몰)

[패스트캠퍼스python] 장고프로젝만들기 전체 순서/흐름도(ft.쇼핑몰)

차근차근 순서대로 Django와 python으로 쇼핑몰을 만들어보자.

1. Django 가상환경설정

  1. 가상환경 virtualenv 설치하기 : pip3 install virtualenv
    • 가상환경은 첫 사용시 한번만 설치하면 된다. 이미 설지채놓았다면 2번 가상환경 폴더만들기부터 진행하면된다.
    • virtualenv는 일반적으로 글로벌 설치가 되어야하는 유일한 패키지이다. 나머지 패키지들은 가상 환경에 설치하기때문이다.
Read More

[ITWILL : JSP]JDBC활용 - JAVA에서 DB 정보 지우기 2가지방법

ITWILL학원 : 19강 JSP기초 BY 정규태강사

JDBC

  1. JDBC활용 - import쓰는 이유, form페이지로 받은 데이터를 DB에 insert하는 방법
  2. JDBC활용 - JAVA에서 DB 정보 지우기 2가지방법
  3. JDBC활용 - DB에서 고객정보를 불러와서 HTML테이블에 담기
  4. JDBC활용 - TIMESTAMP주의점, JDBC에서 데이터처리
  5. JDBC활용 - 회원정보수정페이지만들기
  6. JDBC활용 - 회원목록출력하는데 관리자는 빼고 출력하기, 자바 에러 두종류

JAVA에서 DB 정보 지우기

이름과 주민번호의 입력값이 DB데이터와 일치하면 회원탈퇴를 진행하는 코드를 만들어보자.

1. 사용자가 작성할 form페이지만들기

먼저 이름과 주민번호를 사용자로부터 입력받을 수 있는 deleteForm.jsp파일을 만든다

1
2
3
4
5
6
7
8
9
10
<fieldset>
<legend>회원정보수정</legend>
<form action="deletePro.jsp" method="post" name="fr">
<h3>본인확인정보</h3>
이름 <input type="text" name="name"><br>
주민번호 <input type="text" name="jumin1"> - <input type="password" name="jumin2"><br>
<p></p>
<input type="submit" value="탈퇴하기"><br>
</form>
</fieldset>

2. 사용자가 작성한 데이터를 불러와서 DB에 연결하기

  • deletePro.jsp에서 사용자데이터를 불러와서 DB데이터와 확인 후 탈퇴를 처리하는 코드를 작성하면 아래와 같다.

  • 순서는 아래와 같다

    1. 사용할 변수를 먼저 가져오기
    2. DB연결하기
    3. SQL쿼리작성하기
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<%//1. 변수가져오기
request.setCharacterEncoding("UTF-8");
String name = request.getParameter("name");
String jumin = request.getParameter("jumin1")+"-"+request.getParameter("jumin2");
%>

<%
//2.DB연결
final String DRIVER = "com.mysql.jdbc.Driver";
final String DBURL = "jdbc:mysql://localhost:3306/jspdb";
final String DBID = "root";
final String DBPW = "1234";

Class.forName(DRIVER);
Connection con = DriverManager.getConnection(DBURL, DBID, DBPW);
%>

3. sql작성 & pstmt객체생성

이때 두가지 방법이 있다.

3-1. 바로 delete하기

  • pstmt.executeUpdate();는 return값이 int이므로 int형 변수에 넣은 뒤 if조건문을 통해 진행여부를 html페이지에서 보여줄 수 있다.

  • 사용자입력값이 DB데이터와 일치하면

    • 이클립스 console창에 실행완료(수정완료) : 1 출력
    • html파일에서는 이름과 함께 정상적으로 탈퇴되었습니다라는 문구 출력된다.
  • 사용자입력값이 DB데이터와 불일치하면

    • 이클립스 console창에 실행완료(수정실패) : 0 출력
    • html파일에서는 탈퇴실패 문구 출력된다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<%
//3. sql작성 & pstmt객체생성
String sql = "delete from itwill_member where name=? && jumin=?";
PreparedStatement pstmt = con.prepareStatement(sql);
pstmt.setString(1, name);
pstmt.setString(2, jumin);

int val = pstmt.executeUpdate();
if(val > 0){
System.out.println("실행완료(수정완료) : "+ val);
%><%=name %>님, 정상적으로 탈퇴되었습니다.<%
}else{
System.out.println("실행완료(수정실패) : "+ val);
%>탈퇴실패<%
}
%>

3-2. select 후 delete하기

  • pstmt.executeUpdate();는 return값이 int이므로 int형 변수에 넣은 뒤 if조건문을 통해 진행여부를 html페이지에서 보여줄 수 있다.

  • 사용자입력값이 DB데이터와 일치하는지 select로 확인후 일치하면

    • delete구문으로 데이터 삭제
  • 사용자입력값이 DB데이터와 일치하는지 select로 확인후 불일치하면

    • 삭제동작없이 이전페이지로 이동

DB에서 delete은 매우 신중한 작업이다.
따라서 정확한 데이터를 찾아 정확하게 처리해야하기때문에 전자보단 후자를 사용해야한다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<% //3. sql작성 & pstmt객체생성
String sql = "select name jumin from itwill_member where name=?";
PreparedStatement pstmt = con.prepareStatement(sql);
pstmt.setString(1, name);

ResultSet rs = pstmt.executeQuery();
if(rs.next()){ //레코드셋에서 커서를 옮겨서 데이터가 있을 때 실행하겠다.
//이름과 주민번호가 있는 회원의 정보가 존재한다 =>삭제
if(jumin.equals(rs.getString("jumin"))){
sql = "delete from itwill_member where name=?";
pstmt = con.prepareStatement(sql);
pstmt.setString(1, name);
pstmt.execute();
System.out.println("회원삭제완료");
}else{ //이름은 있지만 주민번호가 다른 경우 =>삭제동작없이 이전페이지로 이동
%>
<script type="text/javascript">
alert("주민번호 오류")
history.back(); //뒤로가기.
</script>
<%
}
}else{
//이름에 해당하는 주민번호가 존재하지않음 => 즉,비회원이므로 삭제동작없이 이전페이지로 이동
%>
<script type="text/javascript">
alert("이름 오류")
history.back(); //뒤로가기.
</script>
<%
}
%>

[ITWILL : JSP]JDBC활용 - import쓰는 이유, form페이지로 받은 데이터를 DB에 insert하는 방법

ITWILL학원 : 19강 JSP기초 BY 정규태강사

JDBC

  1. JDBC활용 - import쓰는 이유, form페이지로 받은 데이터를 DB에 insert하는 방법
  2. JDBC활용 - JAVA에서 DB 정보 지우기 2가지방법
  3. JDBC활용 - DB에서 고객정보를 불러와서 HTML테이블에 담기
  4. JDBC활용 - TIMESTAMP주의점, JDBC에서 데이터처리
  5. JDBC활용 - 회원정보수정페이지만들기
  6. JDBC활용 - 회원목록출력하는데 관리자는 빼고 출력하기, 자바 에러 두종류

1. import는 언제, 왜 쓸까?

어떤 건 import를 쓰고 어떤 건 import하지않고도 사용가능하다.

왜그럴까?

  1. import가 필요없는 경우 : 기본적으로 사용 가능한 클래스인 경우이다.

    • 직접구현해서 접근가능한 범위에서 만들어 놓은 클래스들
    • java 활용도가 높은 클래스를 패키지 추가 없이 사용가능하도록 만들어 놓은 클래스들
      • 예 ) java.lang.*은 자바에서 제공하는 기본패키지로 import없이 사용가능하다. 대표적으로 String 객체는 java.lang.*에 속해있다.
  2. import를 써야하는 경우 : 기본제공되는 클래스가 아닌 경우 클래스가 있는 패키지를 추가(import)해야함

2. form페이지로 받은 데이터를 DB에 insert하는 방법

form페이지를 만들어서 이름과 성별, 나이, 주민번호를 사용자로부터 받은 뒤 그 데이터들을 insertPro.jsp파일에서 불어와서 MySQL DB에 넣어보는 코드이다.

아래 코드는 form페이지는 생략하고 insertPro.jsp만 나타낸 코드이다.

총 3단계로 이루어진다.

  1. form페이지에서 입력한 데이터를 변수로 불러오기
  2. DB연결하기
  3. SQL구문작성 후 stmt객체생성하기 : SQL구문작성시에는 작은 따음표와 큰 따옴표를 잘 입력해야한다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
//import 아래 3가지 추가됨
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.Connection"%>

<%
//1. 변수로 가져오서 데이터출력

//1-1. 파라미터값 한글처리
request.setCharacterEncoding("UTF-8");

//1-2. form태그에서 받은 모든 데이터는 string타입으로 전달되므로 -> int는 형변환필수
String name = request.getParameter("name");
int age = Integer.parseInt(request.getParameter("age"));
String gender = request.getParameter("gender");
String jumin1 = request.getParameter("jumin1");
String jumin2 = request.getParameter("jumin2");
String jumin = jumin1 + "-" + jumin2;
%>

<!--1-3. 데이터출력 -->
이름 : <%=name %><br>
나이 : <%=age %><br>
성별 : <%=gender %><br>
주민번호 : <%=jumin %><br>

<%
//2. DB에 담기
//2-1. 필요한 변수들 상수로 정리
final String DRIVER = "com.mysql.jdbc.Driver";
final String DBURL = "jdbc:mysql://localhost:3306/jspdb";
final String DBID = "root";
final String DBPW = "1234";

//2-2. 드라이버로드
Class.forName(DRIVER);
System.out.println("드라이버로드성공");

//2-3. DB연결
Connection con = DriverManager.getConnection(DBURL, DBID, DBPW);
System.out.println("드라이버연결");

//3. SQL구문작성, stmt 객체생성
//3-1. SQL구문작성 : 작은따옴표와 큰따옴표 주의하기
String sql= "insert into itwill_member values(null,'"+name+"','"+gender+"',"
+age+",'"+jumin+"')";

//3-2. stmt 객체생성(java.sql하위의 statement사용) : sql구문을 실행하는 역할.
Statement stmt = con.createStatement(); //statement객체생성완료

//3-3. stmt 실행
stmt.executeUpdate(sql);
System.out.println("DB저장완료");
%>

MySQL가서 select * from 테이블명 명령어를 입력하면 row가 추가된 것을 확인할 수 있다.

3. PreparedStatement 객체생성

위의 sql구문작성을 보면 변수, 작은따옴표, 큰따옴표혼재되어있어서 적기에 매우 불편하다
이를 해소하기위한 객체PreparedStatement를 이용하면된다.

기존 Statement보다 처리속도도 빠르고 보안도 좋은 PreparedStatement를 사용해야한다.

아래 두 코드를 비교해보자.

3-1. Statement사용

1
2
3
4
5
6
7
8
9
10
11
<%@page import="java.sql.Statement"%>

//1.SQL구문작성
String sql= "insert into itwill_member values(null,'"+name+"','"+gender+"',"
+age+",'"+jumin+"')";

//2. stmt 객체생성(java.sql하위의 statement사용) : sql구문을 실행하는 역할.
Statement stmt = con.createStatement();

//3. stmt 실행
stmt.executeUpdate(sql);

3-2. PreparedStatement사용

3단계 stmt 실행시 기능에 따라 쿼리구문을 두가지로 구분할수있다.

  1. pstmt.executeUpdate() : insert, update, delete에 사용

    • DB조작하는 구문.
  2. pstmt.executeQuery() : select에 사용

    • DB조작없이 값만 사용하는 구문.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<%@page import="java.sql.PreparedStatement"%>

//1. SQL구문작성
String sql= "insert into itwill_member values(null,?,?,?,?)";

//2. pstmt 객체생성(java.sql하위의 prepareStatement사용) : sql구문을 실행하는 역할.
PreparedStatement pstmt = con.prepareStatement(sql);

//물음표 값채우기 pstmt.set테이블데이터타입(물음표위치, 값)
//항상 물음표 갯수와 쿼리구문갯수가 동일해야한다.
pstmt.setString(1, name);
pstmt.setString(2, gender);
pstmt.setInt(3, age);
pstmt.setString(4, jumin);

//3. pstmt 실행 : 업데이트 또는 쿼리
pstmt.executeUpdate();
//pstmt.executeQuery();

[ITWILL : JAVA]클래스 : 매개변수위치에 따른 차이(생성자 vs 메서드), private멤버변수 getter와 setter로 가져다쓰기

ITWILL학원 : 13강 JAVA BY 윤미영강사

1. 매개변수위치에 따른 차이

클래스 Book은 책제목과, 저자, 가격을 출력해준다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public class Book {
private String title;
private String author;
private int price;

public Book(String t, String a, int p){
title = t;
author = a;
price = p;
}

void showInfo(String title, String author, int price ){
System.out.printf("책 제목 : %s, 저자 : %s, 가격 : %,d%n", title, author, price);
}

void showInfo(){
System.out.printf("책 제목 : %s, 저자 : %s, 가격 : %d%n", title, author, price);
}

클래스 TestBook 이라는 새로운 클래스파일을 만들고 메인메서드를 실행해보자.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
public class TestBook {
public static void main(String[] args) {

//생성자파라미터를 통해서 값입력
Book book1 = new Book("운동하는여자", "양민영", 25000);
Book book2 = new Book("채식주의자", "한강", 13500);

//파라미터메서드를 통해서 값입력
Book book3 = new Book();
book3.showInfo("머니", "롭무어", 28000);

//배열생성
Book[] books = new Book[4];

//파라미터가 있는 배열값 넣는 방법2가지

//첫번째방법 : new 이용
books[0] = new Book("며느라기", "수신지", 50000);
//두번째방법 : 객체대입
books[1] = book1;
books[2] = book2;
books[3] = book3;


//배열의 모든값 출력하는 두가지방법
//for문 사용
for(int i=0; i<books.length; i++){
books[i].showInfo();
}

//for each문사용
for(Book b: books){
b.showInfo();
}
}
}
//출력값
책 제목 : 머니, 저자 : 롭무어, 가격 : 28,000

책 제목 : 며느라기, 저자 : 수신지, 가격 : 50000
책 제목 : 운동하는여자, 저자 : 양민영, 가격 : 25000
책 제목 : 채식주의자, 저자 : 한강, 가격 : 13500
책 제목 : null, 저자 : null, 가격 : 0

책 제목 : 며느라기, 저자 : 수신지, 가격 : 50000
책 제목 : 운동하는여자, 저자 : 양민영, 가격 : 25000
책 제목 : 채식주의자, 저자 : 한강, 가격 : 13500
책 제목 : null, 저자 : null, 가격 : 0

1-1 null값이 나오는 이유?

보이는 것처럼 생성자파라미터를 통해서 입력한 값들은 제대로 출력되지만 파라미터메서드를 통해서 입력한 값들은 null로 출력된다.

  • WHY?
    메서드는 파라미터의 값을 받았는데 넣어줄 곳이 없기때문에!

  • 그렇다면 메서드를 어떻게 바꾸면 될까?
    멤버변수를 파라미터값을 대입할수있게 코드를 추가해주면된다

1
2
3
4
5
6
void showInfo(String title, String author, int price ){
this.title = title;
this.author = author;
this.price = price;
System.out.printf("책 제목 : %s, 저자 : %s, 가격 : %,d%n", title, author, price);
}

1-2 어떤 방법이 좋은걸까?

생성자에 파라미터를 받는 방법과 메서드에 파라미터를 받아서 하는 방법 중 어느것이 더 좋은 것일까?

  1. 생성자파라미터
1
2
3
4
5
6
7
8
//1-1.생성자파라미터 생성
public Book(String t, String a, int p){
title = t;
author = a;
price = p;
}
//1-2.생성자파라미터 출력
Book book1 = new Book("운동하는여자", "양민영", 25000)
  1. 파라미터메서드
1
2
3
4
5
6
7
8
9
10
11
//2-1.파라미터메서드 생성
void showInfo(String title, String author, int price ){
this.title = title;
this.author = author;
this.price = price;
System.out.printf("책 제목 : %s, 저자 : %s, 가격 : %,d%n", title, author, price);
}

//2-2. 메서드 출력
Book book1 = new Book();
book3.showInfo("운동하는여자", "양민영", 25000);

둘 다 기능은 동일하지만 생성자파라미터를 쓰는 것이 더 좋다

  • WHY?
    생성자의 기능과 메서드의 기능에 맞게 충실하게 하는 것이 좋기때문이다
    생성자의 기능은 변수를 초기화하는 것이다.
    메서드는 이름에서도 알수있듯이 showInfo()이다. 하지만 파라미터메서드를 생성하면 변수도 초기화하고 출력까지하는 두가지 짬뽕기능을 가지게 된다.

  • 따라서 기능에 맞게 나눠서 코딩하는 것이 좋은 개발습관이다.

2. private 멤버변수값을 사용하는 방법

  • DAO : 주로 jsp model1에서 사용

  • DTO(Data Transfer Object) : 데이터가 포함된 객체를 한 시스템에서 다른 시스템으로 전달하는 작업을 처리하는 클래스이다.

    • 즉, 객체에서 정보가 중요하다. 즉 멤버변수가 중요한 클래스.
    • 정보전달이 중요한 DTO타입의 클래스들은 값을 생성해주는 getter, setter메서드를 만들어야한다
    • 자바빈으로 불리기도 함.
    • 주로 jsp model2에서 사용
    • vs 기능이 중요한 클래스, 라이브러리가 중요한 변수
  • VO(Value Object)

    • DTO와 비슷한 개념
    • 주로 스프링이용할때 사용
  • 멤버변수는 private을 설정하는 것이 데이터보안상 좋다.
    하지만 private을 쓰게되면 다른 클래스에서 가져가 쓸 수가 없다.
    이럴때 아래 두가지 메서드를 이용한다(개발자들의 약속이다).

2-1. getter메서드와 setter메서드

  • 멤버변수의 특정한 값을 가져오고 싶을땐 get멤버변수명().
  • 멤버변수의 특정한 값을 설정하고싶을땐 set멤버변수명().

이를 getter와 setter라고 부른다.

  • Getters and Setters 단축키 : Alt + Shift + S -> R
    • 또는 source탭 Generate Getters and Setters 클릭

2-2. getter와 setter 사용하는 방법

  • getter와 setter 사용하는 코드
1
2
3
4
5
6
//메인메서드안에서 get메서드쓰는 방법
System.out.println(book1.getTitle()); //값가져오기

//메인메서드안에서 set메서드쓰는 방법
book1.setPrice(20000); //값설정
System.out.println(book1.getPrice()); //값가져오기

2-3. getter와 setter 예시

Book 클래스파일은 아래와 같다.
제목과 저자 가격을 멤버변수로 가지고 있다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
public class Book {
private String title;
private String author;
private int price;

public Book(String t, String a, int p){
title = t;
author = a;
price = p;
}

void showInfo(){
System.out.printf("책 제목 : %s, 저자 : %s, 가격 : %d%n", title, author, price);
}

String getTitle(){
return title;
}
String getAuthor(){
return author;
}
int getPrice(){
return price;
}
void setTitle(String title){
this.title = title; //매개변수명과 멤버변수명이 같을때 this를 통해 멤버변수를 지정해줄수있다.
}
void setAuthor(String a){
author = a; //매개변수명과 멤버변수명이 다른경우 그냥 쓰면 된다.
}
void setPrice(int p){
price = p;
}
}

매개변수명과 멤버변수명이 같을때 this를 통해 멤버변수를 지정해줄수있다.

실행하는 메인메서드파일은 아래와 같다.

1
2
3
4
5
6
7
8
Book book1 = new Book("운동하는여자", "양민영", 25000);
System.out.println(book1.getTitle());
book1.setPrice(20000);
System.out.println(book1.setPrice());

//출력값
운동하는여자
20000
MySQL 한글깨짐현상 두가지 해결방법 : cmd와 Workbench, 이클립스와 MYSQL연결
MYSQL 접속순서, DB명령어, 테이블명령어, 데이터명령어

[ITWILL : JSP]쿠키(Cookie)

ITWILL학원 : 17강 JSP기초 BY 정규태강사

  • 클라이언트쪽에서 저장되어 관리되는 정보.

    • 이름, 값, 유효기간 도메인(주소), 경로 … 등등 포함하고 있다.
  • ㅋ쿠기의 이름은 알파벳, 숫자조합으로 생성됨

    • 공백, 괄호, 등호, 콤마, 세미콜론 등등은 인코딩작업 후 쿠키로 사용할 수 있다.
  • 브라우저가 종료되어도 상관없이 지정된 생존기간까지 사용가능.(클라이언트의 HDD하드디스크에 저장되기때문에 브라우저 종료되어도 계속 데이터를 유지할수있다.)

  • 쿠키생성하면서 값을 입력하였다고 쿠키가 메모리 또는 하드디스크에 저장된 것이 아니다. 쿠키를 생성하였으면 생성한 쿠키를 클라이언트로 전송해줘야한다.

  • 단점 : 클라이언트에서 관리되기 때문에 보안에 취약(하드디스크에 있는 쿠키파일 수정할수있기때문)

  • 반대개념은 세션(Session) : 서버쪽에서 저장되어 관리되는 정보, 서버종료되면 사용불가

https://tansfil.tistory.com/58

1-1. 왜 쿠키가 필요할까?

  • 서버는 클라이언트의 1건의 요청에 응답 후 연결을 끊는다.
    WHY?
    서버가 요청오는 모든 클라이언트와 계속 연결이 되어있으면 서버쪽에 부담이 되기때문에!
  • 이때 요청에 응답하면서 쿠키를 함께 보낸다.
    WHY?
    아 옛날에 그 클라이언트구나?! 하면서
    클라이언트를 구분해서 인지할수있고 빠른 응답이 가능하기때문에!

1-2. 쿠키사용방법

  1. 쿠키 생성하기
  • 서버
    1. 서버는 쿠키 객체를 생성
    2. 서버는 쿠키에 필요한 설정을 지정(유효기간, 설명, 도메인, … 등등)
    3. 서버가 생성된 쿠키를 HDD에 저장 후 클라이언트에 쿠키를 전달
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<h1>쿠키테스트(서버 역할)</h1>
<%
//1.쿠키객체생성 : 기본생성자이면 에러가 뜨니 기본값을 직접 입력해주거나 꼭 파라미터를 작성할 것
//아래처럼 직접 입력시 공백있으면 에러남 ex)"Cookie Val!" =>에러발생
Cookie ck = new Cookie("cName", "CookieValue!");

//2.쿠키에 필요한 설정 : 시간설정(사용할 수 있는 시간을 지정)
ck.setMaxAge(600); //초단위, 600초 = 10분(60초*10)

//3.쿠키정보를 저장해서 응답
response.addCookie(ck);
%>

<script type="text/javascript">
alert("쿠키값생성 후 저장됨");
location.href="cookieTest.jsp";
</script>
  1. 쿠키 사용하기
  • 브라우저(클라이언트)
    1. 브라우저에서 요청시 쿠키정보를 가져옴
    2. 쿠키값은 (이름, 값)쌍으로 만들어진 배열.
    3. 쿠키값의 이름을 사용해서 쿠키 객체를 사용.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<h1>쿠키테스트(클라이언트 역할)</h1>
<%
//1. 쿠키정보가져오기
Cookie[] cks = request.getCookies();
String cName="";
String cValue="";

if(cks != null){
for(int i=0; i < cks.length; i++){
if(cks[i].getName().equals("cName")){
//2. 저장된 쿠키 이름을 가져온다
cName = cks[i].getName();
//3. 쿠키값을 가져온다
cValue = cks[i].getValue();
}
}
}
%>

<h2> 쿠키이름 : <%=cName %> </h2>
<h2> 쿠키값 : <%=cValue %> </h2>
<input type="button" value="쿠키값 저장" onclick="location.href='cookieSet.jsp'">
<input type="button" value="쿠키값 삭제" onclick="location.href='cookieDel.jsp'">
  1. 특정 쿠키 삭제하기
  • 쿠키값이 있을때만 삭제진행
  • 쿠키 배열의 처음부터 끝까지 비교하여 쿠키이름이 “cName”인 대상을 찾아서 삭제 -> 변경된 쿠키 정보를 클라이언트에 전달
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<%
//1.쿠키 가져오기 : 지울 쿠키가 있는지부터 체크
Cookie[] cookies = request.getCookies();
String cName="";
String cValue="";

//2. 쿠키값이 있을때만 삭제동작 진행
if(cookies != null){
for(int i=0; i < cookies.length; i++){
// 3. 쿠키이름이 "name"인 대상을 찾아서 삭제 = 쿠키의 유효시간을 0으로 설정하여 만료시킨다
if(cookies[i].getName().equals("cName")){
cookies[i].setMaxAge(0);
// 4. 변경된 쿠기 정보를 다시 클라이언트에 전달
response.addCookie(cookies[i]);
}
}
}
%>
<script type="text/javascript">
alert("쿠키값 삭제 성공")
location.href="cookieTest.jsp"
</script>
  1. 전체 쿠키 삭제
  • 쿠키값이 있을때만 삭제진행
  • 쿠키 배열의 전체를 찾아서 삭제 -> 변경된 쿠키 정보를 클라이언트에 전달
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<%
//1.쿠키 가져오기 : 지울 쿠키가 있는지부터 체크
Cookie[] cookies = request.getCookies();
String cName="";
String cValue="";

//2. 쿠키값이 있을때만 삭제동작 진행
if(cookies != null){
for(int i=0; i < cookies.length; i++){
// 3. 쿠키 전체의 유효시간을 0으로 설정하여 만료시킨다
cookies[i].setMaxAge(0);
// 4. 변경된 쿠기 정보를 다시 클라이언트에 전달
response.addCookie(cookies[i]);
}
}
}
%>
<script type="text/javascript">
alert("쿠키값 삭제 성공")
location.href="cookieTest.jsp"
</script>

1-3. 크롬 개발자도구로 쿠키 확인하기

쿠키를 확인하는 방법은

  1. 크롬 개발자도구를 오픈
  2. NETWORK 탭에서 NAME카테고리에서 내가 만든 jsp파일클릭
  3. Cookies 탭클릭
  4. 세션아이디(jsessionid)위에 쿠기가 생성된 것을 확인할 수 있다.

1-4. 쿠키예시

  1. 쿠키폼페이지 생성하기

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    <h1>쿠키form</h1>

    <!-- 폼태그 언어값에 따라서 달라지는 출력값 구현 -->
    <%
    //1.쿠키정보가져오기

    Cookie[] ck = request.getCookies();
    String lang = "";

    if(ck != null){
    for(int i=0; i<ck.length; i++){
    if(ck[i].getName().equals("lang")){
    lang = ck[i].getValue();
    }
    }
    }

    %>

    <form action="cookiePro.jsp" method="post" name="fr">
    <input type="radio" name="language" value="kor"
    <% if(lang.equals("kor")){ %>
    checked
    <%} %>
    >한국어
    <input type="radio" name="language" value="eng"
    <% if(lang.equals("eng")){ %>
    checked
    <%} %>
    >영어(미국)
    <input type="submit" value="언어설정">
    </form>

    <%
    if(lang.equals("kor")){
    out.print("안녕하세요, 쿠키연습!");
    }else if(lang.equals("eng")){
    out.print("Hello, Cookie Test!");
    }else{ //설정값없을때
    out.print("");
    }
    %>
  2. 쿠키프로페이지 생성하기

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <h1>쿠키pro</h1>

    <%
    System.out.println("라디오버튼 결과값 : "+ request.getParameter("language"));

    //1.쿠키객체생성 : 기본생성자이면 에러가 뜨니 기본값을 직접 입력해주거나 꼭 파라미터를 작성할 것 , 직접입력시 공백있으면에러남
    Cookie ck = new Cookie("lang", request.getParameter("language"));
    //두번째방법 : 첫번째 방법도 쓸수있어야한다(짧은 코드)
    //String lang = request.getParameter("language");
    //Cookie ck = new Cookie("lang", lang);

    //2.쿠키에 필요한 설정 : 시간설정(사용할 수 있는 시간을 지정)
    ck.setMaxAge(120); //초단위, 600초 = 10분(60초*10)
    //3.쿠키정보를 저장해서 응답
    response.addCookie(ck);
    //response.sendRedirect("location href='cookieForm.jsp'");
    %>

    <script type="text/javascript">
    alert("언어설정완료!");
    location.href="cookieForm.jsp";
    </script>