반응형
1. views/board/modify.jsp 생성 (수정할 페이지 만들기 )
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>게시물 수정</title>
</head>
<body>
<form method="post">
<label>제목</label>
<input type="text" name="title" /><br />
<label>작성자</label>
<input type="text" name="writer" /><br />
<label>내용</label>
<textarea cols="50" rows="5" name="content"></textarea><br />
<button type="submit">완료</button>
</form>
</body>
</html>
2. BoardController 수정 코드 추가
package com.board.controller;
import java.util.List;
import javax.inject.Inject;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import com.board.domain.BoardVO;
import com.board.service.BoardService;
@Controller
@RequestMapping("/board/*")
public class BoardController {
@Inject
BoardService service;
@RequestMapping(value = "/list", method = RequestMethod.GET)
public void getList(Model model) throws Exception {
List<BoardVO> list = null;
list = service.list();
model.addAttribute("list", list);
}
// 게시물 작성 (서버에서 사용자로 데이터 이동 GET메서드)
@RequestMapping(value = "/write", method = RequestMethod.GET)
public void getWrite() throws Exception{
}
//게시물 작성 (사용자에서 서버로 데이터 이동 POST메서드
@RequestMapping(value = "/write", method = RequestMethod.POST)
public String postWrite(BoardVO vo) throws Exception{
service.write(vo);
return "redirect:/board/list";
}
//게시물 조회
@RequestMapping(value= "/view", method = RequestMethod.GET)
public void getView(@RequestParam("bno") int bno, Model model) throws Exception{
BoardVO vo = service.view(bno);
model.addAttribute("view", vo);
}
//게시물 수정
@RequestMapping(value = "/modify", method = RequestMethod.GET)
public void getModify() throws Exception {
}
}
3. view.jsp 에서 수정 페이지로 이동할 수 있도록 태그 추가
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>게시물 조회</title>
</head>
<body>
<label>제목</label> ${view.title}
<br />
<label>작성자</label> ${view.writer}
<br />
<label>내용</label> ${view.content }
<div>
<a href="/board/modify?bno=${view.bno}">게시물 수정</a>
</div>
</body>
</html>
4. BoardController 에서 코드 추가
package com.board.controller;
import java.util.List;
import javax.inject.Inject;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import com.board.domain.BoardVO;
import com.board.service.BoardService;
@Controller
@RequestMapping("/board/*")
public class BoardController {
@Inject
BoardService service;
@RequestMapping(value = "/list", method = RequestMethod.GET)
public void getList(Model model) throws Exception {
List<BoardVO> list = null;
list = service.list();
model.addAttribute("list", list);
}
// 게시물 작성 (서버에서 사용자로 데이터 이동 GET메서드)
@RequestMapping(value = "/write", method = RequestMethod.GET)
public void getWrite() throws Exception{
}
//게시물 작성 (사용자에서 서버로 데이터 이동 POST메서드
@RequestMapping(value = "/write", method = RequestMethod.POST)
public String postWrite(BoardVO vo) throws Exception{
service.write(vo);
return "redirect:/board/list";
}
//게시물 조회
@RequestMapping(value= "/view", method = RequestMethod.GET)
public void getView(@RequestParam("bno") int bno, Model model) throws Exception{
BoardVO vo = service.view(bno);
model.addAttribute("view", vo);
}
//게시물 수정
@RequestMapping(value = "/modify", method = RequestMethod.GET)
public void getModify(@RequestParam("bno") int bno, Model model) throws Exception {
BoardVO vo = service.view(bno);
model.addAttribute("view", vo);
}
}
5. modify.jsp에서 코드 추가
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>게시물 수정</title>
</head>
<body>
<form method="post">
<label>제목</label>
<input type="text" name="title" value="${view.title}" /><br />
<label>작성자</label>
<input type="text" name="writer" value="${view.writer}"/><br />
<label>내용</label>
<textarea cols="50" rows="5" name="content">${view.content }</textarea><br />
<button type="submit">완료</button>
</form>
</body>
</html>
6. boardMapper.xml 에 수정용 쿼리 추가
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.board.mappers.board">
<!-- 게시물 목록
resultType은 쿼리를 실행한 뒤 결과가 있을 경우에 사용하며,
반대로 데이터를 넣을 때는 parameterType을 사용
-->
<select id="list" resultType="com.board.domain.BoardVO">
select
bno, title, content, writer, regDate, viewCnt
from tbl_board
</select>
<!-- 게시물 작성
데이터를 넣을 때는 parameterType을 사용
-->
<insert id="write" parameterType="com.board.domain.BoardVO">
insert into
tbl_board(title, content, writer)
values(#{title}, #{content}, #{writer})
</insert>
<!-- 게시물 조회
파라미터 타입은 매퍼에 들어오는 데이터, 리설트 타입은 매퍼가 내보내는 데이터입니다.-->
<select id="view" parameterType="int" resultType="com.board.domain.BoardVO">
select
bno, title, content, regDate, viewCnt
from
tbl_board
where
bno = #{bno}
</select>
<!-- 게시물 수정 -->
<update id="modify" parameterType="com.board.domain.BoardVO">
update tbl_board
set
title = #{title},
content = #{content},
writer = #{writer}
where bno = #{bno}
</update>
</mapper>
7. BoardDAO, BoardDAOImpl 코드 추가
package com.board.dao;
import java.util.List;
import com.board.domain.BoardVO;
public interface BoardDAO {
//게시물 목록
public List<BoardVO> list() throws Exception;
//게시물 작성
public void write(BoardVO vo) throws Exception;
//게시물 조회
public BoardVO view(int bno) throws Exception;
//게시물 수정
public void modify(BoardVO vo) throws Exception;
}
package com.board.dao;
import java.util.List;
import javax.inject.Inject;
import org.apache.ibatis.session.SqlSession;
import org.springframework.stereotype.Repository;
import com.board.domain.BoardVO;
// DAO에 특화된 어노테이션. @Component 어노테이션을 써도 상관 없지만, DAO 클래스들에 @Repository 어노테이션을 사용함으로써
// @Component 어노테이션이 가진 특성과 함께, DAO의 메소드에서 발생할 수 있는 unchecked exception들을 스프링의 DataAccessException으로
// 처리할 수 있는 장점 또한 갖는다.
@Repository
public class BoardDAOImpl implements BoardDAO {
// name으로 DI를 가능케 한다. 자바에서 지원하는 어노테이션이며 프레임워크에 종속적이지 않아 상사용해도 좋다.
// 타입으로 연결한다.
@Inject
private SqlSession sql;
private static String namespace = "com.board.mappers.board";
//게시물 목록
@Override
public List<BoardVO> list() throws Exception {
// TODO Auto-generated method stub
return sql.selectList(namespace + ".list");
}
//게시물 작성
@Override
public void write(BoardVO vo) throws Exception {
sql.insert(namespace + ".write", vo);
}
//게시물 조회
@Override
public BoardVO view(int bno) throws Exception {
return sql.selectOne(namespace + ".view", bno);
}
@Override
public void modify(BoardVO vo) throws Exception {
sql.update(namespace + ".modify", vo);
}
}
8. BoardService, BoardServiceImpl 코드 추가
package com.board.service;
import java.util.List;
import com.board.domain.BoardVO;
public interface BoardService {
//게시물 목록
public List<BoardVO> list() throws Exception;
//게시물 작성
public void write(BoardVO vo) throws Exception;
//게시물 조회
public BoardVO view(int bno) throws Exception;
//게시물 수정
public void modify(BoardVO vo) throws Exception;
}
package com.board.service;
import java.util.List;
import javax.inject.Inject;
import org.springframework.stereotype.Service;
import com.board.dao.BoardDAO;
import com.board.domain.BoardVO;
@Service
public class BoardServiceImpl implements BoardService {
@Inject
private BoardDAO dao;
//게시물 리스트
@Override
public List<BoardVO> list() throws Exception {
// TODO Auto-generated method stub
return dao.list();
}
//게시물 작성
@Override
public void write(BoardVO vo) throws Exception {
dao.write(vo);
}
//게시물 조회
@Override
public BoardVO view(int bno) throws Exception {
return dao.view(bno);
}
@Override
public void modify(BoardVO vo) throws Exception {
dao.modify(vo);
}
}
9. BoardController에서 수정 POST 코드 추가
package com.board.controller;
import java.util.List;
import javax.inject.Inject;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import com.board.domain.BoardVO;
import com.board.service.BoardService;
@Controller
@RequestMapping("/board/*")
public class BoardController {
@Inject
BoardService service;
@RequestMapping(value = "/list", method = RequestMethod.GET)
public void getList(Model model) throws Exception {
List<BoardVO> list = null;
list = service.list();
model.addAttribute("list", list);
}
// 게시물 작성 (서버에서 사용자로 데이터 이동 GET메서드)
@RequestMapping(value = "/write", method = RequestMethod.GET)
public void getWrite() throws Exception{
}
//게시물 작성 (사용자에서 서버로 데이터 이동 POST메서드
@RequestMapping(value = "/write", method = RequestMethod.POST)
public String postWrite(BoardVO vo) throws Exception{
service.write(vo);
return "redirect:/board/list";
}
//게시물 조회
@RequestMapping(value= "/view", method = RequestMethod.GET)
public void getView(@RequestParam("bno") int bno, Model model) throws Exception{
BoardVO vo = service.view(bno);
model.addAttribute("view", vo);
}
//게시물 수정
@RequestMapping(value = "/modify", method = RequestMethod.GET)
public void getModify(@RequestParam("bno") int bno, Model model) throws Exception {
BoardVO vo = service.view(bno);
model.addAttribute("view", vo);
System.out.println("view" + bno);
}
//게시물 수정
@RequestMapping(value ="/modify", method = RequestMethod.POST)
public String postModify(BoardVO vo) throws Exception{
service.modify(vo);
return "redirect:/board/view?bno=" + vo.getBno();
}
}
출처 : https://kuzuro.blogspot.com/2019/08/7.html
수정이 됩니다.
반응형
'2020 > Basic Spring board' 카테고리의 다른 글
#9 스프링 게시판 만들기 ( 게시물 삭제) (0) | 2020.06.11 |
---|---|
#8 스프링 게시판 만들기 ( nav) (0) | 2020.06.11 |
#6 스프링 게시판 만들기 (게시물 조회 구현) (0) | 2020.06.11 |
#5 스프링 게시판 만들기(게시물 작성 구현) (1) | 2020.06.11 |
#4 스프링 게시판 만들기 (게시만 목록 페이지 구현) (1) | 2020.06.10 |