[JSP] - 자신이 쓴 게시물만 삭제하기
○ 자신이 쓴 게시물만 삭제하기 |
// fileDAO.java // 게시물 삭제(유저가 쓴 게시물의 제목으로) public int delete(String userWriteTitle) { PreparedStatement pstmt = null; try { String SQL = "DELETE FROM userwriteTest WHERE userWriteTitle = ?"; pstmt = conn.prepareStatement(SQL); pstmt.setString(1, userWriteTitle); return pstmt.executeUpdate(); } catch (Exception e) { e.printStackTrace(); } finally { try { if(pstmt != null) pstmt.close(); if(conn != null) conn.close(); } catch (Exception e) { e.printStackTrace(); } } return -1; } |
// index.jsp (게시물 출력)
<article class="post-grid">
<a href="userWriteDetailView.jsp?userWriteTitle=<%= write.getTitle() %>&userWriteID=<%= write.getUserWriteID() %>" title="<%=write.getTitle()%>"><div class="post-cover" style="background-image: url('./uploadImage/<%=write.getFileRealName()%>'); opacity: 0.6"></div></a>
// userWriteDetailView.jsp (index에서 출력한 게시물들 상세보기)
<!-- 로그인한 세션 처리 -->
<%
String userSessionID = null;
if (session.getAttribute("userID") != null) {
userSessionID = (String) session.getAttribute("userID");
}
if (userSessionID != null) {
%>
<%
}
%>
<!-- 유저가 쓴 글과 해당 글쓴이를 가져옴 -->
<%
String userWriteTitle = null;
String userWriteID = null;
if (request.getParameter("userWriteTitle") != null) {
userWriteTitle = request.getParameter("userWriteTitle");
}
if (request.getParameter("userWriteID") != null) {
userWriteID = request.getParameter("userWriteID");
}
%>
<!-- 게시물 삭제 -->
<div class="row">
<div class="col-lg-6 mt-3">
<a onclick="return confirm('삭제하시겠습니까?')" href="./userDeleteAction.jsp?userWriteID=<%= userWriteID %>&userWriteTitle=<%=userWriteTitle%>">삭제</a>
</div>
</div>
// userDeleteAction.jsp (실제 삭제가 처리되는 구문)
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="user.UserDAO"%>
<%@ page import="file.fileDAO"%>
<%@ page import="java.io.PrintWriter"%>
<%
// 세션을 통해 userID를 가져옴
String userID = null;
if(session.getAttribute("userID") != null) {
userID = (String) session.getAttribute("userID");
}
// userID의 세션이 없는 경우 로그인 유도
if(userID == null) {
PrintWriter script = response.getWriter();
script.println("<script>");
script.println("alert('로그인을 해주세요.');");
script.println("location.href = 'userLogin.jsp'");
script.println("</script>");
script.close();
return;
}
request.setCharacterEncoding("UTF-8");
// 글쓴이와 글쓴이의 글 제목을 가져옴
String userWriteID = null;
if(request.getParameter("userWriteID") != null) {
userWriteID = (String) request.getParameter("userWriteID");
}
String userWriteTitle = null;
if(request.getParameter("userWriteTitle") != null) {
userWriteTitle = (String) request.getParameter("userWriteTitle");
}
fileDAO file = new fileDAO();
// 로그인한 유저와 글쓴이가 같은지에 따라 처리
if(userID.equals(userWriteID)) {
int result = new fileDAO().delete(userWriteTitle);
if (result == 1) { // 정상처리 시 1반환하여 삭제
session.setAttribute("userID", userID);
PrintWriter script = response.getWriter();
script.println("<script>");
script.println("alert('삭제가 완료되었습니다.');");
script.println("location.href='index.jsp'");
script.println("</script>");
script.close();
return;
} else {
PrintWriter script = response.getWriter();
script.println("<script>");
script.println("alert('데이터베이스 오류가 발생했습니다.');");
script.println("history.back();");
script.println("</script>");
script.close();
return;
}
} else { // 로그인한 유저와 글쓴이가 같지 않으면 처리
PrintWriter script = response.getWriter();
script.println("<script>");
script.println("alert('자신이 쓴 글만 삭제 가능합니다.');");
script.println("history.back();");
script.println("</script>");
script.close();
return;
}
%>
'JSP 개발 참고' 카테고리의 다른 글
[JSP] - 뒤로가기 history.back() 이벤트 (0) | 2018.06.14 |
---|---|
[JSP] - 게시물 추천, 좋아요 중복없이 한번만 하기 (1) | 2018.05.17 |
[JSP] - 이미지컨텐츠 row 분할하여 출력(nth-child) (0) | 2018.05.14 |
[JSP] - 다른 테이블에서 작성자 프로필사진 가져오기 (0) | 2018.05.06 |
[JSP] - 게시물 상세 DB 출력하기 (0) | 2018.05.05 |