[JSP 게시판 만들기] - 특정 게시물을 클릭하여 자세히 보기
○ 특정 게시물을 클릭하여 자세히 보기 |
// ContentDBProcess.java (아래 메소드 추가) // 글제목을 클릭 시 글 내용을 불 수 있게 불러오기 public Content getContent(int contentNum) { String SQL = "SELECT * FROM content WHERE contentNum = ?"; try { PreparedStatement pstmt = conn.prepareStatement(SQL); pstmt.setInt(1, contentNum); rs = pstmt.executeQuery(); if(rs.next()) { // 결과가 나왔다면 Content content = new Content(); content.setContentNum(rs.getInt(1)); content.setContentTitle(rs.getString(2)); content.setContentUser(rs.getString(3)); content.setContentDate(rs.getString(4)); content.setContentDetail(rs.getString(5)); return content; } } catch (Exception e) { e.printStackTrace(); } return null; // 글이 존재하지 않는다면 null 반환 } // ContentView.jsp (새로운 jsp 파일 생성) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.io.PrintWriter" %> <%@ page import="content.Content" %> <%@ page import="content.ContentDBProcess" %> <!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"> <!-- 부트스트랩 사용하기 위해 --> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css"> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script> <title>게시판 내용 링크 시 게시물 내용 확인 페이지</title> </head> <body> <% String userEmail = null; if(session.getAttribute("userEmail") != null){ userEmail = (String) session.getAttribute("userEmail"); } int contentNum = 0; if(request.getParameter("contentNum") != null){ contentNum = Integer.parseInt(request.getParameter("contentNum")); } if(contentNum == 0){ PrintWriter script = response.getWriter(); script.println("<script>alert('유효하지 않는 게시물입니다')</script>"); script.println("<script>location.href = 'content.jsp'</script>"); } Content content = new ContentDBProcess().getContent(contentNum); %> <div class="container"> <h2>게시판 글 보기</h2> <table class="table table-hover"> <tbody> <tr> <td>글 제목</td> <!-- 글 제목 악성 스크립트 공격 막기 위해서 --> <td><%= content.getContentTitle().replaceAll(" ", " ").replaceAll("<", "<").replaceAll(">", ">").replaceAll("\n", "<br>") %></td> </tr> <tr> <td>작성자</td> <td><%= content.getContentUser() %></td> </tr> <tr> <td>작성일자</td> <td><%= content.getContentDate().substring(0, 11) + content.getContentDate().substring(11, 13) + "시 " + content.getContentDate().substring(14, 16) + "분 " %></td> </tr> <tr> <td>글 내용</td> <!-- 출력 시 공백이나 < > 줄바꿈 우리 눈에 보여주기 하기 위해서(html 태그로 인식해서 안되기 때매) --> <td><%= content.getContentDetail().replaceAll(" ", " ").replaceAll("<", "<").replaceAll(">", ">").replaceAll("\n", "<br>") %></td> </tr> </tbody> </table> <!-- 목록으로 돌아가기와 작성자이면 수정할 수 있게 하기 --> <a href = "content.jsp" class="btn btn-primary">목록</a> <% if(userEmail != null && userEmail.equals(content.getContentUser())){ %> <a href="contentUpdate.jsp?contentNum=<%=contentNum %>" class="btn btn-primary">수정</a> <a href="contentDelete.jsp?contentNum=<%=contentNum %>" class="btn btn-primary">삭제</a> <% } %> </div> </body> </html> |
'JSP 게시판 만들기' 카테고리의 다른 글
[JSP 게시판 만들기] - 특정 게시물 삭제하기 (0) | 2018.03.11 |
---|---|
[JSP 게시판 만들기] - 특정 게시물 수정하기 (0) | 2018.03.11 |
[JSP 게시판 만들기] - 게시판에 게시물DB 출력하기 (0) | 2018.03.11 |
[JSP 게시판 만들기] - 글쓰기 기능 + DB 구현하기 (0) | 2018.03.11 |
[JSP 게시판 만들기] - 글쓰기 게시판 만들기 (0) | 2018.03.11 |