admin_modifyForm.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>배송지정보 수정(관리자 전용)</title>
<link rel="stylesheet" href="${pageContext.request.contextPath}/css/style.css" type="text/css">
<c:if test="${order.status == 1}">
<script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-3.7.1.min.js"></script>
<script type="text/javascript">
window.onload=function(){
//배송지정보 유효성 체크
const myForm = document.getElementById('order_modify');
myForm.onsubmit = function(){
const items = document.querySelectorAll('input[type="text"]');
for(let i=0;i<items.length;i++){
if(items[i].value.trim()==''){
const label = document.querySelector(
'label[for="'+items[i].id+'"]');
alert(label.textContent + ' 항목은 필수 입력');
items[i].value = '';
items[i].focus();
return false;
}
if(items[i].id == 'zipcode'
&& !/^[0-9]{5}$/.test(items[i].value)){
alert('우편번호를 입력하세요(숫자5자리)');
items[i].value = '';
items[i].focus();
return false;
}
}//end of for
};
};
</script>
</c:if>
</head>
<body>
<div class="page-main">
<jsp:include page="/WEB-INF/views/common/header.jsp"/>
<div class="content-main">
<h2>배송지정보 수정(관리자 전용)</h2>
<c:if test="${order.status != 1}">
<div class="result-display">
배송대기일 때만 배송지정보를 수정할 수 있습니다.
</div>
</c:if>
<c:if test="${order.status == 1}">
<form action="modify.do" method="post" id="order_modify">
<input type="hidden" name="order_num" value="${order.order_num}">
<ul>
<li>
<label for="receive_name">받는 사람</label>
<input type="text" name="receive_name"
value="${order.receive_name}"
id="receive_name" maxlength="10">
</li>
<li>
<label for="zipcode">우편번호</label>
<input type="text" name="receive_post"
value="${order.receive_post}"
id="zipcode" maxlength="5">
<input type="button" onclick="execDaumPostcode()"
value="우편번호 찾기">
</li>
<li>
<label for="address1">주소</label>
<input type="text" name="receive_address1"
value="${order.receive_address1}"
id="address1" maxlength="30">
</li>
<li>
<label for="address2">상세주소</label>
<input type="text" name="receive_address2"
value="${order.receive_address2}"
id="address2" maxlength="30">
</li>
<li>
<label for="receive_phone">전화번호</label>
<input type="text" name="receive_phone"
value="${order.receive_phone}"
id="receive_phone" maxlength="15">
</li>
<li>
<label for="notice">남기실 말씀</label>
<textarea rows="5" cols="30" name="notice"
id="notice" maxlength="1300">${order.notice}</textarea>
</li>
</ul>
<div class="align-center">
<input type="submit" value="수정">
<input type="button" value="주문목록"
onclick="location.href='orderList.do'">
<input type="button" value="주문목록"
onclick="location.href='adminList.do'">
</div>
</form>
<!-- 다음 우편번호 API 시작 -->
<!-- iOS에서는 position:fixed 버그가 있음, 적용하는 사이트에 맞게 position:absolute 등을 이용하여 top,left값 조정 필요 -->
<div id="layer" style="display:none;position:fixed;overflow:hidden;z-index:1;-webkit-overflow-scrolling:touch;">
<img src="//t1.daumcdn.net/postcode/resource/images/close.png" id="btnCloseLayer" style="cursor:pointer;position:absolute;right:-3px;top:-3px;z-index:1" onclick="closeDaumPostcode()" alt="닫기 버튼">
</div>
<script src="//t1.daumcdn.net/mapjsapi/bundle/postcode/prod/postcode.v2.js"></script>
<script>
// 우편번호 찾기 화면을 넣을 element
var element_layer = document.getElementById('layer');
function closeDaumPostcode() {
// iframe을 넣은 element를 안보이게 한다.
element_layer.style.display = 'none';
}
function execDaumPostcode() {
new daum.Postcode({
oncomplete: function(data) {
// 검색결과 항목을 클릭했을때 실행할 코드를 작성하는 부분.
// 각 주소의 노출 규칙에 따라 주소를 조합한다.
// 내려오는 변수가 값이 없는 경우엔 공백('')값을 가지므로, 이를 참고하여 분기 한다.
var addr = ''; // 주소 변수
var extraAddr = ''; // 참고항목 변수
//사용자가 선택한 주소 타입에 따라 해당 주소 값을 가져온다.
if (data.userSelectedType === 'R') { // 사용자가 도로명 주소를 선택했을 경우
addr = data.roadAddress;
} else { // 사용자가 지번 주소를 선택했을 경우(J)
addr = data.jibunAddress;
}
// 사용자가 선택한 주소가 도로명 타입일때 참고항목을 조합한다.
if(data.userSelectedType === 'R'){
// 법정동명이 있을 경우 추가한다. (법정리는 제외)
// 법정동의 경우 마지막 문자가 "동/로/가"로 끝난다.
if(data.bname !== '' && /[동|로|가]$/g.test(data.bname)){
extraAddr += data.bname;
}
// 건물명이 있고, 공동주택일 경우 추가한다.
if(data.buildingName !== '' && data.apartment === 'Y'){
extraAddr += (extraAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
// 표시할 참고항목이 있을 경우, 괄호까지 추가한 최종 문자열을 만든다.
if(extraAddr !== ''){
extraAddr = ' (' + extraAddr + ')';
}
//(주의)address1에 참고항목이 보여지도록 수정
// 조합된 참고항목을 해당 필드에 넣는다.
//(수정) document.getElementById("address2").value = extraAddr;
}
//(수정) else {
//(수정) document.getElementById("address2").value = '';
//(수정) }
// 우편번호와 주소 정보를 해당 필드에 넣는다.
document.getElementById('zipcode').value = data.zonecode;
//(수정) + extraAddr를 추가해서 address1에 참고항목이 보여지도록 수정
document.getElementById("address1").value = addr + extraAddr;
// 커서를 상세주소 필드로 이동한다.
document.getElementById("address2").focus();
// iframe을 넣은 element를 안보이게 한다.
// (autoClose:false 기능을 이용한다면, 아래 코드를 제거해야 화면에서 사라지지 않는다.)
element_layer.style.display = 'none';
},
width : '100%',
height : '100%',
maxSuggestItems : 5
}).embed(element_layer);
// iframe을 넣은 element를 보이게 한다.
element_layer.style.display = 'block';
// iframe을 넣은 element의 위치를 화면의 가운데로 이동시킨다.
initLayerPosition();
}
// 브라우저의 크기 변경에 따라 레이어를 가운데로 이동시키고자 하실때에는
// resize이벤트나, orientationchange이벤트를 이용하여 값이 변경될때마다 아래 함수를 실행 시켜 주시거나,
// 직접 element_layer의 top,left값을 수정해 주시면 됩니다.
function initLayerPosition(){
var width = 300; //우편번호서비스가 들어갈 element의 width
var height = 400; //우편번호서비스가 들어갈 element의 height
var borderWidth = 5; //샘플에서 사용하는 border의 두께
// 위에서 선언한 값들을 실제 element에 넣는다.
element_layer.style.width = width + 'px';
element_layer.style.height = height + 'px';
element_layer.style.border = borderWidth + 'px solid';
// 실행되는 순간의 화면 너비와 높이 값을 가져와서 중앙에 뜰 수 있도록 위치를 계산한다.
element_layer.style.left = (((window.innerWidth || document.documentElement.clientWidth) - width)/2 - borderWidth) + 'px';
element_layer.style.top = (((window.innerHeight || document.documentElement.clientHeight) - height)/2 - borderWidth) + 'px';
}
</script>
<!-- 다음 우편번호 API 끝 -->
</c:if>
</div>
</div>
</body>
</html>
AdminModifyAction
package kr.order.action;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import kr.controller.Action;
import kr.order.dao.OrderDAO;
import kr.order.vo.OrderVO;
public class AdminModifyAction implements Action{
@Override
public String execute(HttpServletRequest request, HttpServletResponse response) throws Exception {
HttpSession session = request.getSession();
Integer user_num =
(Integer)session.getAttribute("user_num");
if(user_num==null) {
return "redirect:/member/loginForm.do";
}
Integer user_auth = (Integer)session.getAttribute("user_auth");
if(user_auth!=9) {
return "/WEB-INF/views/common/notice.jsp";
}
//전송된 데이터 인코딩 타입 지정
request.setCharacterEncoding("utf-8");
int order_num = Integer.parseInt(
request.getParameter("order_num"));
OrderDAO dao = OrderDAO.getInstance();
//주문정보 호출
OrderVO db_order = dao.getOrder(order_num);
//배송지 수정전 배송상태를 한번 더 체크함
if(db_order.getStatus()>1) {
//배송준비중 이상으로 관리자가 변경한 상품을 주문자가 변경할 수 없음
request.setAttribute("notice_msg",
"배송상태가 변경되어 주문자가 주문정보 변경 불가");
request.setAttribute("notice_url",
request.getContextPath()+"/order/adminDetail.do?order_num"+order_num);
return "/WEB-INF/views/common/alert_view.jsp";
}
OrderVO order = new OrderVO();
order.setOrder_num(order_num);
order.setReceive_name(request.getParameter("receive_name"));
order.setReceive_post(request.getParameter("receive_post"));
order.setReceive_address1(request.getParameter("receive_address1"));
order.setReceive_address2(request.getParameter("receive_address2"));
order.setReceive_phone(request.getParameter("receive_phone"));
order.setNotice(request.getParameter("notice"));
//배송지정보 수정
dao.updateOrder(order);
request.setAttribute("notice_msg",
"정상적으로 수정되었습니다.");
request.setAttribute("notice_url",
request.getContextPath()
+"/order/adminDetail.do?order_num="+order_num);
return "/WEB-INF/views/common/alert_view.jsp";
}
}
kr.item.action = >AdminListAction
package kr.item.action;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import kr.controller.Action;
import kr.item.dao.ItemDAO;
import kr.item.vo.ItemVO;
import kr.util.PagingUtil;
public class AdminListAction implements Action{
@Override
public String execute(HttpServletRequest request, HttpServletResponse response) throws Exception {
HttpSession session = request.getSession();
Integer user_num = (Integer)session.getAttribute("user_num");
if(user_num == null) {
return "redirect:/member/loginForm.do";
}
Integer user_auth = (Integer)session.getAttribute("user_auth");
if(user_auth!=9) {
return "/WEB-INF/views/common/notice.jsp";
}
//관리자로 로그인한 경우
String pageNum = request.getParameter("pageNum");
if(pageNum==null) pageNum ="1";
String keyfield = request.getParameter("keyfield");
String keyword = request.getParameter("keyword");
ItemDAO dao = ItemDAO.getInstance();
//status가 0이면 미표시(1),표시(2) 모두 개수 반환
int count = dao.getItemCount(keyfield,keyword,0);
//페이지 처리
PagingUtil page = new PagingUtil(keyfield,keyword,Integer.parseInt(pageNum),count,20,10,"adminList.do");
List<ItemVO> list = null;
if(count > 0) {
list = dao.getListItem(page.getStartRow(), page.getEndRow(), keyfield, keyword, 0);
}
request.setAttribute("count",count);
request.setAttribute("list",list);
request.setAttribute("page",page.getPage());
return "/WEB-INF/views/item/admin_list.jsp";
}
}
ItemDAO 내용추가
//관리자/사용자 - 전체 상품 개수/ 검색 상품 개수
public int getItemCount(String keyfield,String keyword,int status)throws Exception{
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
String sql =null;
String sub_sql = "";
int count = 0;
int cnt = 0;
try {
//커넥션풀로부터 커넥션 할당
conn = DBUtil.getConnection();
if(keyword !=null && !"".equals(keyword)) {
if(keyfield.equals("1")) sub_sql += "AND name LIKE '%' || ? || '%'";
else if(keyfield.equals("2")) sub_sql += "AND detail LIKE '%' || ? || '%'";
}
//SQL문 작성
sql="SELECT COUNT(*) FROM zitem WHERE status > ?" + sub_sql;
//PreparedStatment 객체 생성
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, status);
if(keyword !=null && !"".equals(keyword)) {
pstmt.setString(2, keyword);
}
rs = pstmt.executeQuery();
if(rs.next()) {
count = rs.getInt(1);
}
//SQL실행
}catch(Exception e) {
throw new Exception(e);
}finally {
DBUtil.executeClose(rs, pstmt, conn);
}
return count;
}
views/item =>admin_list.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>상품관리</title>
<link rel="stylesheet" href="${pageContext.request.contextPath}/css/style.css" type="text/css">
<script type="text/javascript">
window.onload = function(){
const myForm = document.getElementById('search_form');
//이벤트 연결
myForm.onsubmit = function(){
const keyword = document.getElementById('keyword');
if(keyword.value.trim()==''){
alert('검색어를 입력하세요');
keyword.value='';
keyword.focus();
return false;
}
};
}
</script>
</head>
<body>
<div class="page-main">
<jsp:include page="/WEB-INF/views/common/header.jsp"/>
<div class="content-main">
<h2>상품관리</h2>
<form id="search_form" action="adminList.do" method="get">
<ul class="search">
<li>
<select name="keyfield">
<%-- c:if와 selected를 쓰는건 검색을 계속 유지 시키기 위해서 --%>
<option value="1" <c:if test="${param.keyfield ==1}">selected</c:if>>제목</option>
<option value="2" <c:if test="${param.keyfield ==2}">selected</c:if>>작성자</option>
</select>
</li>
<li>
<input type="search" size="16" name="keyword" id="keyword" value="${param.keyword}">
</li>
<li>
<input type="submit" value="검색">
</li>
</ul>
</form>
<div class="list-space align-right">
<input type="button" value="상품등록"
onclick="location.href='adminWriteForm.do'"
<c:if test="${empty user_num}">disabled="disabled" </c:if> <%-- 비홯성화 시키는 법 --%>
> <!-- input 닫는 꺽쇄 -->
<input type="button" value="목록" onclick="location.href='list.do'">
<input type="button" value="홈으로" onclick="location.href='${pageContext.request.contextPath}/main/main.do'">
</div>
<c:if test="${count==0}">
<div class="result-display">
표시할 상품이 없습니다.
</div>
</c:if>
<c:if test="${count>0}">
<table>
<tr>
<th>번호</th>
<th>상품명</th>
<th>가격</th>
<th>재고수</th>
<th>등록일</th>
<th>상태</th>
</tr>
<c:forEach var="item" items="${list}">
<tr>
<td>${item.item_num}</td>
<td><a href="adminModifyForm.do?item_num=${item.item_num}">${item.name}</a></td>
<td><fmt:formatNumber value="${item.price}"/></td>
<td><fmt:formatNumber value="${item.quantity}"/></td>
<td>${item.reg_date}</td>
<td>
<c:if test="${item.status ==1}">미표시</c:if>
<c:if test="${item.status ==2}">표시</c:if>
</td>
</tr>
</c:forEach>
</table>
<div class="align-center">${page}</div>
</c:if>
</div>
</div>
</body>
</html>
AdminModifyFormAction
package kr.item.action;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import kr.controller.Action;
import kr.item.dao.ItemDAO;
import kr.item.vo.ItemVO;
public class AdminModifyFormAction implements Action{
@Override
public String execute(HttpServletRequest request, HttpServletResponse response) throws Exception {
HttpSession session = request.getSession();
Integer user_num = (Integer)session.getAttribute("user_num");
if(user_num==null) {
return "redirect:/member/loginForm.do";
}
Integer user_auth = (Integer)session.getAttribute("user_auth");
if(user_auth !=9) {
return "/WEB-INF/views/common/notice.jsp";
}
int item_num = Integer.parseInt(request.getParameter("item_num"));
ItemDAO dao = ItemDAO.getInstance();
ItemVO item = dao.getItem(item_num);
request.setAttribute("item",item);
return "/WEB-INF/views/item/admin_modifyForm.jsp";
}
}