jb.log

..loading

jsp 프로젝트 만들기 - DB연결

September 30, 2019

JDBC를 이용하여 자바 웹 프로젝트에 mysql을 연동하여 프로그램을 이어 나가겠다. JDBC는 자바에서 데이터베이스에 접속할 수 있도록 하는 자바 API이다. JDBC는 데이터베이스에서 자료를 쿼리하거나 업데이트하는 방법을 제공한다.

mysql table 생성

이번 프로젝트는 mysql을 이용할 예정이다. 먼저 mysql table을 다음과 같이 생성해 주자.

CREATE TABLE board (
  `id` INT NOT NULL AUTO_INCREMENT,
  `title` VARCHAR(45) NOT NULL,
  `writer_id` VARCHAR(45) NOT NULL,
  `content` TEXT NOT NULL,
  `hit` INT NULL,
  `created_at` DATETIME NOT NULL,
  `files` VARCHAR(100) NULL,
  PRIMARY KEY (`id`));

JDBC 사용하기

만들어 놓은 자바 웹 프로젝트에 JDBC 를 사용하여 Mysql 데이터베이스를 연동할 것다. jdbc는 jdk를 설치하면 기본적으로 java.sql 하위에 내장되어 있지만, 사용자에 따라 오라클 또는 mysql 과 같은 다른 DB를 사용할 수 있기 때문에 연결할 틀만 제공해준다. 따라서 사용자는 사용할 DB의 드라이버를 다운 받아 사용해야 한다.

mysql connector 설치

라이브러리를 사용하기 위해선 해당 jar파일을 프로젝트에 추가해주어야 한다. 이전 자바 프로젝트와는 달리 servlet 프로젝트는 WEB-INF/lib 하위 경로에 파일을 추가해 주어야한다.

우리가 웹 프로젝트를 완성하면 실제 사용할 서버에 배포를 해주어야 하는데 해당 라이브러리를 같이 가져가서 사용하게 할 목적이다.

  • https://mvnrepository.com/artifact/mysql/mysql-connector-java/8.0.18 해당 주소에 접속한다.
  • file에 jar파일을 다운받는다.
  • 프로젝트의 /WEB-INF/lib 하위에 해당 jar 파일을 넣어준다. (만약 .zip파일로 압축 되어 있다면 내부의 mysql-connector-java-8.0.20.jar 과 같은 파일만 빼서 넣어주어야 함)

프로젝트에 DB 연동

이전에 만들어논 3개의 페이지 index, board-list, board-detail 문서중 board-detail.jsp 를 예제로 db를 연동하여 데이터를 웹에 출력해보자.

board-detail.jsp 문서의 제일 상단에 스크랩트립 <% %>을 사용하여 다음 내용을 넣어보자.


//getConnection에 필요한 파라미터 각 mysql의 url, 사용자 아이디, 비밀번호를 받는다.
String url = "jdbc:mysql://localhost:3306?characterEncoding=UTF-8&serverTimezone=UTC";
String id = "root";
String pw = "woqja5164!";

//라이브러리로 받은 mysql connector의 Driver 클래스를 JVM에게 알려준다. 메모리에 올라감
Class.forName("com.mysql.cj.jdbc.Driver");

//java.sql.DriverManager 를 사용하여 mysql에 대한 정보를 주고 Connection 이 참조
Connection con = DriverManager.getConnection(url,id,pw);

자바 파일에 작성했다면 Class.forNameClassNotFoundException예외를, DriverManager.getConnectionSQLException 예외를 처리 해주어야 하지만 스크랩트릿 내부에서의 코드는 예외 처리가 필요 없다. 위 코드를 입력 후 http://localhost:8080/details/board-detail.jsp 에 접속시 화면이 잘 뜬다면 성공적으로 연결한 것이다.

DB의 데이터를 웹에 보여주기

board-detail.jsp를 다음과 같이 수정한다.

<%@page import="java.util.Date"%>
    그 밖의 import... 
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%
String url = "jdbc:mysql://localhost:3306?characterEncoding=UTF-8&serverTimezone=UTC";
String id = "root";
String pw = "woqja5164!";

String sql = "SELECT * FROM example01.board where id = 1";
    
Class.forName("com.mysql.cj.jdbc.Driver");
Connection con = DriverManager.getConnection(url,id,pw);
Statement state = con.createStatement();
ResultSet result = state.executeQuery(sql);

result.next();
%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <nav>
        <a href="/">홈</a>
        <a href="/lists/board-list.jsp">게시글 목록</a>
    </nav>
    <hr/>
    <h1>제목 : <%= result.getString("title") %> </h1>
    <p>작성자:<%= result.getString("writer_id") %> / 작성일: <%= result.getDate("created_at") %>/ 조회수: <%= result.getInt("hit") %>  </p>
    <p>첨부 파일:<%= result.getString("files") %> </p>
    <div style="width:500px; height:300px; border:2px dotted gray; padding:10px;">
        <%= result.getString("content") %>
    </div>
    <hr/>
    <a href="">다음 글</a>
    <span style="font-weight:bold">/</span>
    <a href="">이전 글</a>
</body>
</html>
<%
con.close();
state.close();
result.close();
%>

http://localhost:8080/details/board-detail.jsp 위 문서를 브라우저에서 실행하면 다음과 같은 화면을 볼 수 있다. board-detail.jsp

위의 코드를 보면 java 코드를 담기 위한 스크립트릿과 html이 뒤엉켜있는 것을 볼 수 있다. 위와 같은 코드를 스파게티 코드라고 한다. 혼자 프로젝트를 만들때는 괜찮겠지만, 기업에서의 협업, 또는 프로젝트의 규모가 커질 수 록 관리하기 힘든 점이 있다. 그래서 MVC1이라는 패턴이 나왔는데 다음 글에 이어서 다루도록 하겠다.

# 해당 글은 개인적인 공부 내용을 정리하는 것을 목적으로 하고있습니다.# 설명이 다소 부족하거나 중간 내용이 생략될 수 있습니다.

Other Posts

October 1, 2019
jsp 프로젝트 만들기 - mvc1, mvc2
이전에 만든 `board-detail.jsp`은 DB와 잘 연결되어 화면에 데이터를 잘 출력하는 것을 볼 수 있다. 하지만 jsp 파일 내의 코드를 보면 자바코드와 html코드가 뒤엉켜 있는 것을 볼 수 있다. 이것을 스파게티 코드라 한다.
September 29, 2019
jsp 프로젝트 만들기 - 시작
본격적으로 jsp를 이용한 servlet 프로젝트를 만들어보겠다. jsp와 servlet의 활용 목적이 주된 내용이기 html/css 는 가급적 손대지 않고 비즈니스 로직에 집중하도록 하겠다.
September 25, 2019
jsp 프로그래밍
jsp란 `Java Server Pages` 의 약자이며 HTML 코드에 JAVA 코드를 넣어 동적웹페이지를 생성하는 웹어플리케이션 도구이다.
September 24, 2019
Servlet 상태관리
서블릿은 요청이 오면 응답을 주고 메모리에서 사라지기 때문에 서블릿들 간의 연결이 불가능하다. 만약 기존의 데이터를 저장할 일이 생겼다고 하면 서블릿 스스로 저장할 수 있는 것은 아니다. 이것은 ServletContext로 해결할 수 있다.
September 22, 2019
한글 인코딩
servlet 클래스에서 한글을 출력하면 한글이 깨지는 것을 볼 수 있다. 해당 문제점은 다음과 같이 해결할 수 있다.
September 20, 2019
Servlet 다루기
기존의 html 문서만으로는 동적인 내용을 전달할 수 없다. 때문에 WAS(web application server) 에서 동작하는 프로그래밍 언어를 사용하면 가능하다.