1 분 소요

안녕하세요. Nerd-Lee입니다.
공부 내용은, 인프런 박매일님의 [NarP Series]MVC 프레임워크는 내 손에[나프1탄] 을 참고하였습니다.
MVC 1단계인, Servlet 환경으로만 만들어보고, MVC 2단계로 넘어가고
나중에는 Spring Framework를 사용하는 방식의 강의입니다.
MVC 1단계는, Controller + Model 만을 사용하는 방식입니다.

진도가 빠르게 나가지 않아, 중요하다고 생각하는 부분들만 작성할 예정입니다.


1. 회원 테이블에 삭제 버튼 추가하기

  • 테이블에 삭제 버튼을 만들어주자.
@WebServlet("/memberList.do")
public class MemberListController extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void service(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		// 1. 클라이언트 요청 받기
		
		// 2. 회원 전체리스트 가져오기(Model과 연동)
		MemberDAO dao = new MemberDAO();
		ArrayList<MemberVO> list = dao.memberGetList();

		// 3. 회원 전체리스트 HTML로 만들어서 출력(응답)
		response.setContentType("text/html;charset=utf-8");// MIME TYPE
		PrintWriter out = response.getWriter();
		out.println("<html>");
		out.println("<body>");
		out.println("<table border='1'>");
		out.println("<thead>");
		out.println("<tr>");
		out.println("<th>번호</th>");
		out.println("<th>아이디</th>");
		out.println("<th>패스워드</th>");
		out.println("<th>이름</th>");
		out.println("<th>나이</th>");
		out.println("<th>이메일</th>");
		out.println("<th>전화번호</th>");
		out.println("<th>삭제</th>");
		out.println("</tr>");
		out.println("</thead>");
		out.println("<tbody>");

		for (MemberVO vo : list) {
			out.println("<tr>");
			out.println("<td>" + vo.getNumber() + "</td>");
			out.println("<td>" + vo.getId() + "</td>");
			out.println("<td>" + vo.getPassword() + "</td>");
			out.println("<td>" + vo.getName() + "</td>");
			out.println("<td>" + vo.getAge() + "</td>");
			out.println("<td>" + vo.getEmail() + "</td>");
			out.println("<td>" + vo.getPhone() + "</td>");
			out.println("<th><a href='/memberDelete.do?num="+vo.getNumber()+"'>삭제</a></th>");
			out.println(" </tr>");
		}
		out.println("</tbody>");
		out.println("<tr>");
		out.println("<td colspan='8' align='right'>");
		out.println("<a href='member/memberRegister.html'>회원가입</a>");
		out.println("</td>");
		out.println("</tr>");
		out.println("</table>");
		out.println("</body>");
		out.println("</html>");
	}
}

2. Delete 관련 Servlet을 만들자.

  • controller 패키지에, MemberDeleteController 라는 서블릿을 하나 만들어준다.
  • 그리고, 삭제를 할 때 해당 회원의 number 값을 memberDelete.do에 넘겨줘야 한다.
  • 그 때 사용하는 것이 쿼리스트링(querystring) 이다.
  • 쿼리스트링 값은, service에서 request가 가지고 있다. request에서, 값을 받아와서
    DAO로 넘겨서 DB 쿼리를 실행하면 된다.
//[delete Servlet]

@WebServlet("/memberDelete.do")
public class MemberDeleteController extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// 1. 쿼리스트링 값 파라미터 빼오기
		int number = Integer.parseInt(request.getParameter("num"));
		
		MemberDAO dao = new MemberDAO();
		
		int success = dao.memberDelete(number);
		
		if(success > 0) {
			response.sendRedirect("/memberList.do");
		}
		else {
			// 가입 실패시 예외객체를 만들어서 WAS(톰캣서버) 에게 던진다.
			throw new ServletException("not delete!");
		}
	}
}

// [MemberDAO 추가]

// 선택 회원 삭제하기
	public int memberDelete(int number) {
		String SQL = "delete from member where number=?";
		int success = -1;
		
		// 데이터베이스 연결
		getConnect();
		
		try {
			ps = conn.prepareStatement(SQL);
			
			ps.setInt(1, number);
			success = ps.executeUpdate();
		}
		catch (Exception e) {
			e.printStackTrace();
		}
		finally {
			dbClose();
		}
		
		return success;
	}


이 글이 도움이 되셨다면 댓글 부탁드립니다^^
다음 글로 찾아오겠습니다!