K 개발자
JSP BookMarket 만들기 - 12 본문
이전 글
JSP BookMarket 만들기 - 1
JSP BookMarket 만들기 - 2
JSP BookMarket 만들기 - 3
JSP BookMarket 만들기 - 4
JSP BookMarket 만들기 - 5
JSP BookMarket 만들기 - 6
JSP BookMarket 만들기 - 7
JSP BookMarket 만들기 - 8
JSP BookMarket 만들기 - 9
JSP BookMarket 만들기 - 10
JSP BookMarket 만들기 - 11
실행 환경
자바 개발 환경 : jdk-15.0.2
웹 서버 환경 : Apache Tomcat v9.0
통합 개발 환경 : Eclipse IDE for Enterprise Java Developers
장바구니 페이지 만들기
src 폴더의 Book 클래스에 멤버 변수를 추가한다.
- 장바구니에 담은 도서의 개수를 관리하도록 멤버 변수 quantity를 선언한다.
- 추가된 멤버 변수의 Setter/Getter() 메소드를 각각 작성한다.
// Book.java
package dto;
import java.io.Serializable;
public class Book implements Serializable {
private static final long serialVersionUID = -4274700572038677000L;
private String bookId; // 도서 아이디
private String name; // 도서명
private Integer unitPrice; // 가격
private String author; // 저자
private String description; // 설명
private String publisher; // 출판사
private String category; // 분류
private long unitsInStock; // 재고 수
private long totalPages; // 페이지 수
private String releaseDate; // 출판일(월/년)
private String condition; // 신규 도서 or 중고 도서 or E-Book
private String filename; // 이미지 파일명
private int quantity; // 장바구니에 담은 개수
public Book() {
super();
}
public Book(String bookId, String name, Integer unitPrice) {
this.bookId = bookId;
this.name = name;
this.unitPrice = unitPrice;
}
public String getBookId() {
return bookId;
}
public void setBookId(String bookId) {
this.bookId = bookId;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getUnitPrice() {
return unitPrice;
}
public void setUnitPrice(Integer unitPrice) {
this.unitPrice = unitPrice;
}
public String getAuthor() {
return author;
}
public void setAuthor(String author) {
this.author = author;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String getPublisher() {
return publisher;
}
public void setPublisher(String publisher) {
this.publisher = publisher;
}
public String getCategory() {
return category;
}
public void setCategory(String category) {
this.category = category;
}
public long getUnitsInStock() {
return unitsInStock;
}
public void setUnitsInStock(long unitsInStock) {
this.unitsInStock = unitsInStock;
}
public long getTotalPages() {
return totalPages;
}
public void setTotalPages(long totalPages) {
this.totalPages = totalPages;
}
public String getReleaseDate() {
return releaseDate;
}
public void setReleaseDate(String releaseDate) {
this.releaseDate = releaseDate;
}
public String getCondition() {
return condition;
}
public void setCondition(String condition) {
this.condition = condition;
}
public String getFilename() {
return filename;
}
public void setFilename(String filename) {
this.filename = filename;
}
public int getQuantity() {
return quantity;
}
public void setQuantity(int quantity) {
this.quantity = quantity;
}
}
WebContent 폴더의 도서 상세 정보 페이지 book.jsp 파일을 수정한다.
- <도서주문> 버튼을 추가하고 이 버튼을 누르면 장바구니에 추가할 것인지를 확인하는 핸들러 함수가 실행되도록 작성한다.
- <장바구니> 버튼을 추가하고 이 버튼을 누르면 장바구니 페이지가 실행되도록 작성한다.
<%-- book.jsp --%>
<%@ page contentType="text/html; charset=utf-8"%>
<%@ page import="dto.Book"%>
<%@ page import="dao.BookRepository"%>
<%@ page errorPage="exceptionNoBookId.jsp"%>
<html>
<head>
<link rel="stylesheet" href="./resources/css/bootstrap.min.css">
<title>도서 상세 정보</title>
<script type="text/javascript">
function addToCart() {
if (confirm("도서를 장바구니에 추가하시겠습니까?")) {
document.addForm.submit();
} else {
document.addForm.reset();
}
}
</script>
</head>
<body>
<jsp:include page="menu.jsp" />
<div class="jumbotron">
<div class="container">
<h1 class="display-4">도서 정보</h1>
</div>
</div>
<%
String id = request.getParameter("id");
BookRepository dao = BookRepository.getInstance();
Book book = dao.getBookById(id);
%>
<div class="container">
<div class="row">
<div class="col-md-4">
<img src="c:/upload/<%=book.getFilename()%>" style="width: 100%" />
</div>
<div class="col-md-8">
<h4><b>[<%=book.getCategory()%>]<%=book.getName()%></b></h4>
<p><%=book.getDescription()%>
<p><b>도서코드 : </b><span class="badge badge-danger"> <%=book.getBookId()%></span>
<p><b>저자</b> : <%=book.getAuthor()%>
<p><b>출판사</b> : <%=book.getPublisher()%>
<p><b>출판일</b> : <%=book.getReleaseDate()%>
<p><b>총 페이지수</b> : <%=book.getTotalPages()%>
<p><b>재고수</b> : <%=book.getUnitsInStock()%>
<h4><%=book.getUnitPrice()%>원</h4>
<p><form name="addForm" action="./addCart.jsp?id=<%=book.getBookId()%>" method="post">
<a href="#" class="btn btn-info" onclick="addToCart()">도서주문 »</a>
<a href="./cart.jsp" class="btn btn-warning">장바구니 »</a>
<a href="./books.jsp" class="btn btn-secondary">도서목록 »</a>
</form>
</div>
</div>
<hr>
</div>
<jsp:include page="footer.jsp" />
</body>
</html>
WebContent 폴더에 장바구니에 등록하는 페이지 addCart.jsp 파일을 생성하고 선택한 도서가 장바구니에 등록되도록 작성한다.
<%-- addCart.jsp --%>
<%@ page contentType="text/html; charset=utf-8"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="dto.Book"%>
<%@ page import="dao.BookRepository"%>
<%
String id = request.getParameter("id");
if (id == null || id.trim().equals("")) {
response.sendRedirect("books.jsp");
return;
}
BookRepository dao = BookRepository.getInstance();
Book book = dao.getBookById(id);
if (book == null) {
response.sendRedirect("exceptionNoBookId.jsp");
}
ArrayList<Book> goodsList = dao.getAllBooks();
Book goods = new Book();
for (int i = 0; i < goodsList.size(); i++) {
goods = goodsList.get(i);
if (goods.getBookId().equals(id)) {
break;
}
}
ArrayList<Book> list = (ArrayList<Book>) session.getAttribute("cartlist");
if (list == null) {
list = new ArrayList<Book>();
session.setAttribute("cartlist", list);
}
int cnt = 0;
Book goodsQnt = new Book();
for (int i = 0; i < list.size(); i++) {
goodsQnt = list.get(i);
if (goodsQnt.getBookId().equals(id)) {
cnt++;
int orderQuantity = goodsQnt.getQuantity() + 1;
goodsQnt.setQuantity(orderQuantity);
}
}
if (cnt == 0) {
goods.setQuantity(1);
list.add(goods);
}
response.sendRedirect("book.jsp?id=" + id);
%>
WebContent 폴더에 cart.jsp 파일을 생성하고 장바구니에 등록된 목록을 출력하도록 작성한다.
<%-- cart.jsp --%>
<%@ page contentType="text/html; charset=utf-8"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="dto.Book"%>
<%@ page import="dao.BookRepository"%>
<html>
<head>
<link rel="stylesheet" href="./resources/css/bootstrap.min.css" />
<%
String cartId = session.getId();
%>
<title>장바구니</title>
</head>
<body>
<jsp:include page="menu.jsp" />
<div class="jumbotron">
<div class="container">
<h1 class="display-3">장바구니</h1>
</div>
</div>
<div class="container">
<div class="row">
<table width="100%">
<tr>
<td align="left"><a href="./deleteCart.jsp?cartId=<%=cartId%>"
class="btn btn-danger">삭제하기</a></td>
<td align="right"><a href="#" class="btn btn-success">주문하기</a></td>
</tr>
</table>
</div>
<div style="padding-top: 50px">
<table class="table table-hover">
<tr>
<th>도서</th>
<th>가격</th>
<th>수량</th>
<th>소계</th>
<th>비고</th>
</tr>
<%
int sum = 0;
ArrayList<Book> cartList = (ArrayList<Book>) session.getAttribute("cartlist");
if (cartList == null)
cartList = new ArrayList<Book>();
for (int i = 0; i < cartList.size(); i++) { // 도서 리스트 하나씩 출력하기
Book book = cartList.get(i);
int total = book.getUnitPrice() * book.getQuantity();
sum = sum + total;
%>
<tr>
<td><%=book.getBookId()%> - <%=book.getName()%></td>
<td><%=book.getUnitPrice()%></td>
<td><%=book.getQuantity()%></td>
<td><%=total%></td>
<td><a href="./removeCart.jsp?id=<%=book.getBookId()%>"
class="badge badge-danger">삭제</a></td>
</tr>
<%
}
%>
<tr>
<th></th>
<th></th>
<th>총액</th>
<th><%=sum%></th>
<th></th>
</tr>
</table>
<a href="./books.jsp" class="btn btn-secondary">« 쇼핑 계속하기</a>
</div>
<hr>
</div>
<jsp:include page="footer.jsp" />
</body>
</html>
WebContent 폴더에 removeCart.jsp 파일을 생성하고 선택한 도서가 삭제되도록 작성한다.
<%-- removeCart.jsp --%>
<%@ page contentType="text/html; charset=utf-8"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="dto.Book"%>
<%@ page import="dao.BookRepository"%>
<%
String id = request.getParameter("id");
if (id == null || id.trim().equals("")) {
response.sendRedirect("books.jsp");
return;
}
BookRepository dao = BookRepository.getInstance();
Book book = dao.getBookById(id);
if (book == null) {
response.sendRedirect("exceptoinNoBookId.jsp");
}
ArrayList<Book> cartList = (ArrayList<Book>) session.getAttribute("cartlist");
Book goodsQnt = new Book();
for (int i = 0; i < cartList.size(); i++) {
goodsQnt = cartList.get(i);
if (goodsQnt.getBookId().equals(id)) {
cartList.remove(goodsQnt);
}
}
response.sendRedirect("cart.jsp");
%>
WebContent 폴더에 deleteCart.jsp 파일을 생성하고 모든 도서가 삭제되도록 작성한다.
<%-- deleteCart.jsp --%>
<%@ page contentType="text/html; charset=utf-8"%>
<%@ page import="dto.Book"%>
<%@ page import="dao.BookRepository"%>
<%
String id = request.getParameter("cartId");
if (id == null || id.trim().equals("")) {
response.sendRedirect("cart.jsp");
return;
}
session.invalidate();
response.sendRedirect("cart.jsp");
%>
웹 브라우저에 'http://localhost:8080/BookMarket/books.jsp'를 입력하여 실행 결과를 확인한다.
'Web > JSP' 카테고리의 다른 글
JSP BookMarket 만들기 - 마지막 (1) | 2021.08.06 |
---|---|
JSP BookMarket 만들기 - 13 (0) | 2021.08.06 |
JSP BookMarket 만들기 - 11 (0) | 2021.08.06 |
JSP BookMarket 만들기 - 10 (0) | 2021.08.06 |
JSP BookMarket 만들기 - 9 (0) | 2021.08.06 |