웹로그조회

개요

웹로그조회는 사용자의 웹페이지 접근시 발생하는 각종 로그를 검색, 조회하는 기능을 제공한다.

설명

  • 웹로그조회는 웹로그의 등록, 조회, 목록, 삭제, 요약의 기능을 수반한다.
  ① 웹로그등록 : 웹로그정보를 등록한다. - Interceptor 기능을 이용 
  ② 웹로그조회 : 웹로그정보의 상세내용을 조회한다.
  ③ 웹로그목록 : 웹로그정보의 목록을 검색, 조회한다.
  ④ 웹로그삭제 : 웹로그정보를 삭제한다. - 실행환경의 Scheduling 기능을 이용
  ⑤ 웹로그요약 : 웹로그정보를 요약하여 Summary를 생성한다. - 실행환경의 Scheduling 기능을 이용 

관련 리소스

클래스

유형대상소스명비고
Controlleregovframework.com.sym.log.web.EgovLogManageController.java웹로그 관리를 위한 컨트롤러 클래스
Serviceegovframework.com.sym.log.service.EgovLogManageService.java웹로그 관리를 위한 서비스 인터페이스
ServiceImplegovframework.com.sym.log.service.impl.EgovLogManageServiceImpl.java웹로그 관리를 위한 서비스 구현 클래스
DAOegovframework.com.sym.log.service.impl.LogManageDAO.java웹로그 관리를 위한 데이터처리 클래스
VOegovframework.com.sym.log.service.WebLogVO.java웹로그 관리를 위한 VO 클래스
Interceptoregovframework.com.sym.log.web.EgovWebLogInterceptor.java웹로그 등록을 위한 Interceptor 클래스
Scheduleregovframework.com.sym.log.service.EgovLogManageScheduling.java웹로그 삭제, 요약을 위한 Scheduling 클래스
JSP/WEB-INF/jsp/egovframework/cmm/sym/log/EgovWebLogList.jsp웹로그 목록을 위한 jsp페이지
JSP/WEB-INF/jsp/egovframework/cmm/sym/log/EgovWebLogInqire.jsp웹로그 조회를 위한 jsp페이지

클래스 다이어그램

테이블

테이블명테이블명(영문)비고
웹로그COMTNWEBLOG웹로그 정보를 관리
웹로그요약COMTSWEBLOGSUMMARY웹로그 요약정보를 관리

ID Generation

context-idgen.xml
  <bean name="egovWebLogIdGnrService"
    class="egovframework.rte.fdl.idgnr.impl.EgovTableIdGnrService"
    destroy-method="destroy">
    <property name="dataSource" ref="dataSource" />
    <property name="strategy"   ref="webLogStrategy" />
    <property name="blockSize"  value="1"/>
    <property name="table"      value="COMTECOPSEQ"/>
    <property name="tableName"  value="WEBLOG_ID"/>
  </bean>
 
  <bean name="webLogStrategy"
    class="egovframework.rte.fdl.idgnr.impl.strategy.EgovIdGnrStrategyImpl">
    <property name="prefix" value="WEBLOG_" />
    <property name="cipers" value="13" />
    <property name="fillChar" value="0" />
  </bean>
  • ID Generation Service를 활용하기 위해서 Sequence 저장테이블인 COMTECOPSEQ에 WEBLOG_ID 항목을 추가한다.
  INSERT INTO COMTECOPSEQ VALUES('WEBLOG_ID','0');
 

Interceptor

egov-com-interceptor.xml
  <bean id="egovWebLogInterceptor" class="egovframework.com.sym.log.web.EgovWebLogInterceptor" />
 
  <bean id="webLogMapping" class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
    <property name="interceptors">
      <list>
        <ref bean="egovWebLogInterceptor" />
      </list>
    </property> 
  </bean>

웹로그 등록 기능구현을 위하여 Interceptor를 설정한다.

  • 웹로그 등록 기능구현을 위하여 EgovWebLogInterceptor 클래스를 생성한다.
package egovframework.com.sym.log.web;
 
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
 
import egovframework.com.sec.ram.security.userdetails.util.EgovUserDetailsHelper;
import egovframework.com.sym.log.service.EgovLogManageService;
import egovframework.com.sym.log.service.WebLog;
import egovframework.com.uat.uia.service.LoginVO;
 
public class EgovWebLogInterceptor extends HandlerInterceptorAdapter {
 
  @Resource(name="EgovLogManageService")
  private EgovLogManageService logManageService;
 
  /**
   * 웹 로그정보를 생성한다.
   * 
   * @param HttpServletRequest request, HttpServletResponse response, Object handler 
   * @return 
   * @throws Exception 
   */
  @Override
  public void postHandle(HttpServletRequest request,
      HttpServletResponse response, Object handler, ModelAndView modeAndView) throws Exception {
 
    WebLog webLog = new WebLog();
    String reqURL = request.getRequestURI();
    String uniqId = "";
 
      /* Authenticated  */
        Boolean isAuthenticated = EgovUserDetailsHelper.isAuthenticated();
      if(isAuthenticated.booleanValue()) {
      LoginVO user = (LoginVO)EgovUserDetailsHelper.getAuthenticatedUser();
      uniqId = user.getUniqId();
      }
 
    webLog.setUrl(reqURL);
    webLog.setRqesterId(uniqId);
    webLog.setRqesterIp(request.getRemoteAddr());
 
    logManageService.logInsertWebLog(webLog);
 
  }
}

Scheduling

context-scheduling.xml
  <!-- 웹 로그 요약  -->
  <bean id="webLogging"
    class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
    <property name="targetObject" ref="egovLogManageScheduling" />
    <property name="targetMethod" value="webLogSummary" />
    <property name="concurrent" value="false" />
  </bean>
 
  <!-- 웹 로그 요약  트리거-->
  <bean id="webLogTrigger"
    class="org.springframework.scheduling.quartz.SimpleTriggerBean">
    <property name="jobDetail" ref="webLogging" />
    <!-- 시작하고 1분후에 실행한다. (milisecond) -->
    <property name="startDelay" value="60000" />
    <!-- 매 1시간마다 실행한다. (milisecond) -->
    <property name="repeatInterval" value="3600000" />
  </bean>
 
  <!-- 스케쥴러 등록-->
  <bean id="logSummaryScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
    <property name="triggers">
      <list>
        <ref bean="sysLogTrigger" />
        <ref bean="webLogTrigger" />
        <ref bean="trsmrcvLogTrigger" />
        <ref bean="userLogTrigger" />
      </list>
    </property>
  </bean>

웹로그 삭제, 요약 기능구현을 위하여 Scheduling을 설정한다.

  • 웹로그 삭제, 요약 기능구현을 위하여 EgovLogManageScheduling 클래스를 생성한다.
@Service("egovLogManageScheduling")
public class EgovLogManageScheduling {
 
  @Resource(name="EgovLogManageService")
  private EgovLogManageService logManageService;
 
  /**
   * 웹 로그정보를 요약한다.
   * 전날의 로그를 요약하여 입력하고, 일주일전의 로그를 삭제한다.
   * 
   * @param 
   * @return
   * @throws Exception 
   */
  public void webLogSummary() throws Exception {
    logManageService.logInsertWebLogSummary();
  }
 

관련화면 및 수행메뉴얼

웹로그 목록조회

ActionURLController methodQueryID
목록조회/cmm/sym/log/SelectWebLogList.doselectWebLogInf“LogManageDAO.selectWebLogInf”
“LogManageDAO.selectWebLogInfCnt”

웹로그 목록은 페이지 당 10건씩 조회되며 페이징은 10페이지씩 이루어진다. 검색조건은 발생일자와 URL에 대해서 수행된다.

웹로그 상세조회 기능을 수행하기 위해서는 상세보기 버튼을 클릭한다.


웹로그 상세조회

ActionURLController methodQueryID
상세조회/cmm/sym/log/InqireWebLog.doselectWebLog“LogManageDAO.selectWebLog”

웹로그 상세조회는 팝업창으로 구성되며, 닫기 버튼을 클릭하면 창을 닫는다.


참고자료

 
egovframework/웹로그조회.txt · 마지막 수정: 2023/12/21 05:21 (외부 편집기)
 
이 위키의 내용은 다음의 라이센스에 따릅니다 :CC Attribution-Noncommercial-Share Alike 3.0 Unported
전자정부 표준프레임워크 라이센스(바로가기)

전자정부 표준프레임워크 활용의 안정성 보장을 위해 위험성을 지속적으로 모니터링하고 있으나, 오픈소스의 특성상 문제가 발생할 수 있습니다.
전자정부 표준프레임워크는 Apache 2.0 라이선스를 따르고 있는 오픈소스 프로그램입니다. Apache 2.0 라이선스에 따라 표준프레임워크를 활용하여 발생된 업무중단, 컴퓨터 고장 또는 오동작으로 인한 손해 등에 대해서 책임이 없습니다.
Recent changes RSS feed CC Attribution-Noncommercial-Share Alike 3.0 Unported Donate Powered by PHP Valid XHTML 1.0 Valid CSS Driven by DokuWiki