Riucc's Storage
RSS
태그
관리
쓰기
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
Riucc's Storage

[NodeJS] - 게시판 상세페이지 MySQL 연동하여 출력하기

NodeJS|2018. 12. 25. 20:17
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

○ 게시판 상세페이지 MySQL 연동하여 출력하기


핵심은 게시글 제목에 a href에 게시글 번호를 출력하여 넣어주고

route parametes 를 이용하여 게시글 번호를 받아서 

해당 번호의 게시물만 출력하게끔 하는 것이다


// notice.ejs 


<table class="noticeTable">
<colgroup>
<col width="80">
<col width="*">
<col width="150">
</colgroup>
<thead>
<tr>
<th><span>번호</span></th>
<th><span>제목</span></th>
<th><span>등록일</span></th>
</tr>
</thead>
<tbody>
<% for(var i=0; i< notice_result.length; i++) {%>
<tr>
<td class="text-center"><%= notice_result[i].noticeNo %></td>
<td id="td_title"><a href="/notice/<%=notice_result[i].noticeNo%>">
<%= notice_result[i].noticeTitle %></a> </td>
<td class="text-center"><%= notice_result[i].noticeDate %></td>
</tr>
<% }; %>
</tbody>
</table>


// notice.js


// 메인에서 사이드메뉴 공지사항 세션유지해서 가기(어드민인지에 따라 작성버튼 없애야함)
// 데이터베이스에 있는 공지사항 데이터들 출력
router.route('/').get(function(req, res) {

    // 커넥션 풀에서 연결 객체를 가져옴
    pool.getConnection(function(err, conn) {
if (err) {
    if (conn) {
conn.release(); // 반드시 해제해야 함
}
callback(err, null);
return;
}
console.log('데이터베이스 연결 스레드 아이디 : ' + conn.threadId);

// SQL 문을 실행함
const sql = 'select noticeNo, noticeTitle, noticeDate
from notice order by noticeNo desc limit 10;';
conn.query(sql, function(err, result) {
conn.release(); // 반드시 해제해야 함
console.log(result);
console.log(result[0].noticeTitle); // 데이터 db에서 잘받아 들어갔나 테스트용
res.render('notice.ejs',
{userSessionId : req.session.userID, notice_result: result});
});
});
});


// notice_detail.ejs


<!-- 공지 출력 부분 -->
<section>
<div class="Notice" style="margin-top:70px;">
<div class="NoticeView">
<div class="container">
<div class="UIOPanelBox">
<h3 style="margin-bottom: 30px;">공지사항</h3>
<div class="noticeViewTitle"><%= notice_result[0].noticeTitle %>
<span><%= notice_result[0].noticeDate %></span></div>
<div class="noticeContents" style="white-space: pre-line;">
<div><span><%= notice_result[0].noticeDesc %></span></div>
</div>
<div class="btnWrap text-right" style="margin-top: 15px;">
<!-- 로긴 유저가 어드민일 시 삭제 버튼 토출되게 -->
<% if(userSessionId == "admin") { %>
<a class="btn btn-outline-primary"
href="/notice/delete/<%= notice_result[0].noticeNo %>"
style="margin-right: 20px;">삭제</a>
<% } %>
<a class="btn btn-outline-primary" href="/notice">목록</a>
</div>
</div>
</div>
</div>
</div>
</section>


// notice.js


// 공지사항 공지 게시물 출력된거 각각 찾아가기
// 데이터베이스에 있는 해당 게시물 No에 대한 데이터 출력
router.route('/:noticeNumber').get(function(req, res) {
    // 커넥션 풀에서 연결 객체를 가져옴
    pool.getConnection(function(err, conn) {
if (err) {
    if (conn) {
conn.release(); // 반드시 해제해야 함
}
callback(err, null);
return;
}
console.log('데이터베이스 연결 스레드 아이디 : ' + conn.threadId);

// 페이지 번호를 가져와서 대입(라우트 파라매터)
var noticeNumber2 = path.parse(req.params.noticeNumber).base;

if(noticeNumber2=="notice_write"){
res.render('notice_write.ejs', {userSessionId : req.session.userID});
}else{
// SQL 문을 실행함
conn.query('SELECT noticeNo, noticeTitle, noticeDesc,
noticeDate FROM notice WHERE noticeNo=?', [noticeNumber2], function(err, result) {
conn.release(); // 반드시 해제해야 함
console.log(result);
res.render('notice_detail.ejs',
{userSessionId : req.session.userID, notice_result: result});
});
}
});
});


저작자표시 (새창열림)

'NodeJS' 카테고리의 다른 글

[Javascript] - 카운트다운 타이머에 디자인 입히기  (0) 2019.02.19
[Javascript] - 카운트다운으로 남은날짜시간 구하기  (0) 2019.02.19
[NodeJS] - Visual Studio Code(VSC) 코드 들여쓰기 단축기  (0) 2018.12.16
[NodeJS] - MySQL 연동해서 데이터 출력 시 줄바꿈 방법  (0) 2018.12.04
[NodeJS] - MySQL 연동하기(Connection Pool), delete문  (0) 2018.12.03

댓글()
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
최근 등록 현황
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
달력
지난달
2025.9
다음달
일월화수목금토
123456
78910111213
14151617181920
21222324252627
282930
태그 구름
  • 정보처리산업기사 총정리
  • 안드로이드 카카오 로그인
  • 리눅스
  • nodejs MySQL 연동하기(Connection Pool)
  • 정보처리산업기사 16년 필기
  • 데이터베이스
  • 이클립스 mysql 연동
  • 정규화
  • 정보처리산업기사 요약
  • jsp
  • 정보처리산업기사 15년 필기
  • HTML
  • 소켓 프로그래밍
  • 카카오 로그인 연동
  • 정보처리산업기사 필기 정리
  • 정보처리산업기사 15년
  • 정규형
  • 소켓
  • 정보처리산업기사 필기
  • 안드로이드
  • 이클립스 디비 연동
  • 카카오 로그인
  • 정보처리산업기사 16년
  • 커널 모듈 프로그래밍
  • nodejs express
  • 정보처리기사 실기 정리
  • 정보처리산업기사 정리
  • 안드로이드 카카오 로그인 연동
  • 자료구조
  • 안드로이드 intent
카운터
전체 방문자
오늘
어제
Skin by M1REACT. Designed by M1STORY.TISTORY.COM. Valid XHTML 1.0 and CSS 3. Copyright ⓒ Riucc's Storage. All rights reserved.

티스토리툴바