확실히 db연동부분은 쉽군요-_-; try catch도 안해도 되고, 커넥션 같은것도 스프링에서 다 알아서 해줘요-_-;
처음 틀만 제대로 만들어놓으면 개발하는데에는 더 속도가 빨라질 것 같아요.









우선 ListController클래스를 봅시다.
[code]
List<GuestbookVO> contentslist = getGuestbookManager().getContents();  
return new ModelAndView("list", "contentslist", contentslist);
[/code]
멤버변수로 있는 guestbookManager는 springapp-servlet.xml에서 알아서 셋팅되니 우리는 그냥 getter만 하면 됩니다. 가져와서 getContents()메소드를 호출하면 List를 다 가져오는 메소드입니다.

자세히 보도록 합시다.
GuestbookManagerDao클래스는 인터페이스입니다. GuestbookManagerDaoJdbc클래스는 저 인터페이스를 구현해 놓은 클래스입니다.
getContents()메소드
[code]
@SuppressWarnings("unchecked")
public List<GuestbookVO> getContents() {
 
  jdbcTemplate = new JdbcTemplate(dataSource);
  String query =
  "SELECT no, name, subject, content, ip, datetime FROM guestbook ORDER BY no DESC";
 
  List<GuestbookVO> contentslist =
                   (List<GuestbookVO>)jdbcTemplate.queryForList(query);
 
  return contentslist;
 }
[/code]
코드를 보니 예전에 스트럿츠에서하던 try-catch-finally는 다 걷어버리고, 딸랑 몇개만 남았어요. 커넥션하는것도 없어요-_-; 매우 간단해요!-_-;
아....참고로 저렇게 해도 나쁜방식입니다. 원래는 하나하나 매핑해줘야한다더군요.(이것도 아이군한테 혼났어요-_-;)
dataSource는 xml에서 다 해주니 새로운 jdbcTemplate을 생성합니다. 이 생성된 jdbcTemplate이 제공하는 메소드중에 queryForList라는게 있는데 query를 주면 자동으로 List형태로 반환해주는 메소드입니다.
저렇게 리스트 형식으로 받게 됩니다. 자동으로 가져오는 것보다 매퍼라는게 있는데 그걸로 매핑해서 하는게 명확한 표현입니다.
아 그리고 저렇게하면 워링이 뜨는데 그건 프레임워크에서 만들어진 List형에 아무것도 안붙어있기때문이죠.
jdk1.5.0이상부터는 List에는 형태를 명시해주기로 되어있어요. ex) List<GuestbookVO>
가볍게 무시를 해줍시다-_-;
이클립스에서 해주는데 @SuppressWarnings("unchecked") 라고하면 워링이 사라집니다.

이제 Controller는 이 List를 받아서 list.jsp을 요청하면 List를 넘겨줍니다.
list.jsp를 봅시다.
[code]
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ include file="/WEB-INF/jsp/include.jsp" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title><fmt:message key="title"/></title>
</head>
<body>

<form action="write.do" method="post">

이름 : <input name="name" type="text"/>
제목 : <input name="subject" type="text"/><br />
내용 : <br /><textarea name="content" rows="10" cols="50"></textarea><br />
<br />
<input type="submit" value="글쓰기"/>
<br />
<spring:hasBindErrors name="guestbookWrite">
 <b>필드를 채워주세요!</b>
</spring:hasBindErrors>
<hr />
</form>
<c:forEach var="contentslist" items="${contentslist}">
 <div>
 <p>이름 : ${contentslist.name}</p>
 <p>제목 : ${contentslist.subject}</p>
 <p>내용 : ${contentslist.content}</p>
 <p>아이피 : ${contentslist.ip}</p>
 <p>날짜 : ${contentslist.datetime}</p>
 </div>
 <hr />
</c:forEach>

</body>
</html>
[/code]
spring태그는 우선 가볍게 무시합시다. 위에 쓰기위한 폼이 있고, 아래에는 forEach를 통해 반복하고 있군요.
list.jsp에 딸려온 contentslist에 있는 것을 반복해서 출력해줍니다.
저거 el표기법인데 구글에서 가볍게 검색해서 공부해봅시다(사실 저도 잘 모릅니다-_-;)
jstl도 가볍게 검색해주고-_-;

 
Posted by 머드초보
,