knu project
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

142 lines
7.9 KiB

/**
* ***********************************************************************************************
* 프로그램명 : HttpDocDel.java 프로그램설명 : 집계 문서 삭제 파라미터 작성자 : 작성일 : 변경일 :
*************************************************************************************************
*/
package kr.co.kihyun.beans.totsys.totper;
import java.io.IOException;
import java.io.PrintWriter;
import java.net.URLEncoder;
import javax.jdo.PersistenceManager;
import javax.jdo.Transaction;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import kr.co.kihyun.beans.entity.TotDoc;
//import kr.co.kihyun.beans.entity.TotDocType;
import kr.co.kihyun.beans.entity.util.*;
import kr.co.kihyun.beans.user.HttpSSOLogin;
import kr.co.kihyun.lang.Encoder;
import kr.co.kihyun.lang.MLong;
import kr.co.kihyun.lang.MString;
import kr.co.kihyun.moumi.MoumiConfig;
import kr.co.kihyun.text.html.ServletUtil;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@WebServlet("/servlet/kr.co.kihyun.beans.totsys.totper.HttpDocDel")
public class HttpDocDel extends HttpServlet {
private static final long serialVersionUID = 1L;
private static final Logger LOG = LoggerFactory.getLogger(HttpDocDel.class);
public void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
res.setContentType("text/html;charset=UTF-8");
PrintWriter out = res.getWriter();
/**
* ********* User HttpSSOLogin check **********
*/
if (!HttpSSOLogin.isLogin(req)) {
// login 성공후 되돌아올 주소
String connURL = "location='/totsys/login/login.jsp';";
out.println(ServletUtil.getJavaScript(connURL));
return;
}
String usID = HttpSSOLogin.getLoginID(req);
String docID = Encoder.toJava(req.getParameter("docID"));
String userID = HttpSSOLogin.getLoginID(req);
String url = Encoder.toJava(req.getParameter("url"));
String docType = MString.checkNull(req.getParameter("docType"));
String strPage = (String) Encoder.toJava(req.getParameter("strPage"));
String findOption = MString.checkNull(Encoder.toJava(req.getParameter("findOption")));
// String findWord = MString.checkNull(Encoder.toJava(req.getParameter("findWord")));
String findWord = MString.checkNull(req.getParameter("findWord"));
String stDate = MString.checkNull(req.getParameter("stDate"));
String edDate = MString.checkNull(req.getParameter("edDate"));
int sysAuth = HttpSSOLogin.getSysAuth(req);
TotDoc totDoc = null;
PersistenceManager pm = new MPersistenceManager(PMF.get().getPersistenceManager());
Transaction tx = pm.currentTransaction();
try {
tx.begin();
if (!"endDoc".equals(url)) {
totDoc = pm.getObjectById(TotDoc.class, MLong.parseLong(docID));
}
if (!"endDoc".equals(url) && !userID.equals(totDoc.getUser(pm).getId()) && sysAuth == MoumiConfig.TOTPER) {
out.println(ServletUtil.alert(MoumiConfig.getMessageBundle().getString("moumi.message.popup.totDocDeleteFail")));
//out.println(ServletUtil.getJavaScript("document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "';"));
out.println(ServletUtil.getJavaScript("document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "&strPage="+ strPage + "&findOption="+ findOption + "&findWord="+ findWord + "&stDate=" + stDate + "&edDate=" + edDate + "';"));
return;
}
if (!"endDoc".equals(url)) {
totDoc.setDeleted("Y");
if (totDoc.getMasterTotDoc() != null) {
totDoc.setMasterTotDoc(null);
}
pm.makePersistent(totDoc);
} else {
String[] docIDList = null;
docIDList = docID.split(",");
for (int i = 0; i < docIDList.length; i++) {
totDoc = pm.getObjectById(TotDoc.class, MLong.parseLong(docIDList[i]));
if (sysAuth > MoumiConfig.TOTPER) {
totDoc.setDeleted("Y");
if (totDoc.getMasterTotDoc() != null) {
totDoc.setMasterTotDoc(null);
}
pm.makePersistent(totDoc);
} else {
if (userID.equals(totDoc.getUser(pm).getId())) {
totDoc.setDeleted("Y");
if (totDoc.getMasterTotDoc() != null) {
totDoc.setMasterTotDoc(null);
}
pm.makePersistent(totDoc);
}
}
}
}
tx.commit();
LOG.info(MoumiConfig.getMessageBundle().getString("moumi.message.tot_doc") + MoumiConfig.getMessageBundle().getString("moumi.message.tot_report.delete") + MoumiConfig.getMessageBundle().getString("moumi.message.tot_doc.success") + " {}, {}, {}",
new Object[]{usID, req.getRemoteAddr(), docID});
//out.println(ServletUtil.getJavaScript("document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "';"));
out.println(ServletUtil.getJavaScript("document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "&strPage="+ strPage + "&findOption="+ findOption + "&findWord="+ URLEncoder.encode(MString.checkNull(findWord), "UTF-8") + "&stDate=" + stDate + "&edDate=" + edDate + "';"));
// System.out.println("url location ::: " + stDate + " :: " + edDate );
// out.println(ServletUtil.getJavaScript("document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "&strPage="+ strPage + "';"));
} catch (Exception e) {
e.printStackTrace();
LOG.error(MoumiConfig.getMessageBundle().getString("moumi.message.tot_doc") + MoumiConfig.getMessageBundle().getString("moumi.message.tot_report.delete") + MoumiConfig.getMessageBundle().getString("moumi.message.tot_doc.fail") + " {}, {}, {}",
new Object[]{usID, req.getRemoteAddr(), docID});
out.println(ServletUtil.alert(MoumiConfig.getMessageBundle().getString("moumi.message.tot_doc") + MoumiConfig.getMessageBundle().getString("moumi.message.tot_report.delete") + MoumiConfig.getMessageBundle().getString("moumi.message.tot_doc.fail")));
//out.println(ServletUtil.getJavaScript("document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "';"));
//v2. 9.크로스사이트 스크립트 (PrintWrier) : Update by KWON,HAN
// out.println(ServletUtil.getJavaScript("document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "&strPage="+ strPage + "&findOption="+ findOption + "&findWord="+ findWord + "';"));
// 수정 : 외부 입력값 필터링
String callbackFunc = "document.location='/totsys/totper/mydocbox/prssbox/doc_list.jsp?docType=" + docType + "&strPage="+ strPage + "&findOption="+ findOption + "&findWord="+ findWord + "&stDate=" + stDate + "&edDate=" + edDate + "';";
String filtered_callbackFunc = callbackFunc.replaceAll("<","").replaceAll(">","").replaceAll(",","");
LOG.debug("v2 9.크로스사이트 스크립트 (PrintWrier) : HttpDocDel.doPost() filtered_callbackFunc={}, Not Test", filtered_callbackFunc);
out.println(ServletUtil.getJavaScript(filtered_callbackFunc));
//========================================
} finally {
if (tx.isActive()) {
tx.rollback();
}
pm.close();
}
}
}