접속로그관리

개요

접속로그관리는 사용자가 시스템 로그인/아웃한 로그를 검색, 조회하는 기능을 제공한다.

설명

접속로그관리는 로그인 패키지(egovframework-certlogin-2.0.0.zip) 설치 후에 사용이 가능하다.
(단독 설치 후 실행 시 에러발생)

접속로그관리는 로그인로그의 등록, 조회, 목록의 기능을 수반한다.

  ① 접속로그등록 : 로그인로그정보를 등록한다. - AOP 기능을 이용
  ② 접속로그조회 : 로그인로그정보의 상세내용을 조회한다.
  ③ 접속로그목록 : 로그인로그정보의 목록을 검색, 조회한다.

패키지 참조 관계

접속로그관리 패키지는 요소기술의 공통(cmm) 패키지에 대해서만 직접적인 함수적 참조 관계를 가진다. 하지만, 컴포넌트 배포 시 오류 없이 실행되기 위하여 패키지 간의 참조관계에 따라 달력 패키지와 함께 배포 파일을 구성한다.

관련소스

유형대상소스명비고
Controlleregovframework.com.sym.log.clg.web.EgovLoginLogController.java접속로그 관리를 위한 컨트롤러 클래스
Serviceegovframework.com.sym.log.clg.service.EgovLoginLogService.java접속로그 관리를 위한 서비스 인터페이스
ServiceImplegovframework.com.sym.log.clg.service.impl.EgovLoginLogServiceImpl.java접속로그 관리를 위한 서비스 구현 클래스
Modelegovframework.com.sym.log.clg.service.LoginLog.java접속로그 관리를 위한 VO 클래스
DAOegovframework.com.sym.log.clg.service.impl.LoginLogDAO.java접속로그 관리를 위한 데이터처리 클래스
Aspectegovframework.com.sym.log.clg.service.EgovLoginLogAspect.java접속로그 등록을 위한 Aspect 클래스
JSP/WEB-INF/jsp/egovframework/com/sym/log/clg/EgovLoginLogList.jsp접속로그 목록을 위한 jsp페이지
JSP/WEB-INF/jsp/egovframework/com/sym/log/clg/EgovLoginLogInqire.jsp접속로그 조회를 위한 jsp페이지
QUERY XMLresources/egovframework/sqlmap/com/sym/log/clg/EgovLoginLog_SQL_Mysql.xml접속로그 관리 MySQL용 QUERY XML
QUERY XMLresources/egovframework/sqlmap/com/sym/log/clg/EgovLoginLog_SQL_Oracle.xml접속로그 관리 Oracle용 QUERY XML
QUERY XMLresources/egovframework/sqlmap/com/sym/log/clg/EgovLoginLog_SQL_Tibero.xml접속로그 관리 Tibero용 QUERY XML
QUERY XMLresources/egovframework/sqlmap/com/sym/log/clg/EgovLoginLog_SQL_Altibase.xml접속로그 관리 Altibase용 QUERY XML
Idgen XMLresources/egovframework/spring/context-idgen.xml접속로그 관리 Id생성 Idgen XML

클래스 다이어그램

ID Generation

ID Generation 관련 DDL 및 DML

  • ID Generation Service를 활용하기 위해서 Sequence 저장테이블인 COMTECOPSEQ에 LOGINLOG_ID 항목을 추가한다.
  CREATE TABLE COMTECOPSEQ ( table_name varchar(16) NOT NULL, 
  		   next_id DECIMAL(30) NOT NULL,
  		   PRIMARY KEY (table_name));
 
  INSERT INTO COMTECOPSEQ VALUES('LOGINLOG_ID','0');
 

ID Generation 환경설정(context-idgen.xml)

  <bean name="egovLoginLogIdGnrService"
    class="egovframework.rte.fdl.idgnr.impl.EgovTableIdGnrService"
    destroy-method="destroy">
    <property name="dataSource" ref="dataSource" />
    <property name="strategy"   ref="loginLogStrategy" />
    <property name="blockSize"  value="1"/>
    <property name="table"      value="COMTECOPSEQ"/>
    <property name="tableName"  value="LOGINLOG_ID"/>
  </bean>
 
  <bean name="loginLogStrategy"
    class="egovframework.rte.fdl.idgnr.impl.strategy.EgovIdGnrStrategyImpl">
    <property name="prefix" value="LOGIN_" />
    <property name="cipers" value="14" />
    <property name="fillChar" value="0" />
  </bean>

관련 테이블

테이블명테이블명(영문)비고
접속로그COMTNLOGINLOG로그인로그 정보를 관리한다.

AOP

egov-com-loginaop.xml

        <bean id="egov.loginlog" class="egovframework.com.sym.log.clg.service.EgovLoginLogAspect" />
 
	<aop:config>
		<aop:aspect id="egov.loginLogAspect" ref="egov.loginlog">
			<!--  로그인 Method -->
			<aop:before pointcut="execution(public * egovframework.com.uat.uia.web.EgovLoginController.actionMain(..))" method="logLogin" />
			<!--  로그아웃 Method -->
			<aop:before pointcut="execution(public * egovframework.com.uat.uia.web.EgovLoginController.actionLogout(..))" method="logLogout" />
		</aop:aspect>
	</aop:config>

시스템로그 등록 기능구현을 위하여 AOP를 설정한다.

  • 시스템로그 등록 기능구현을 위하여 EgovLogManageAspect 클래스를 생성한다.
package egovframework.com.sym.log.clg.service;
 
import javax.annotation.Resource;
 
import egovframework.com.cmm.LoginVO;
import egovframework.com.cmm.util.EgovUserDetailsHelper;
 
public class EgovLoginLogAspect {
 
	@Resource(name="EgovLoginLogService")
	private EgovLoginLogService loginLogService;
 
	/**
	 * 로그인 로그정보를 생성한다.
	 * EgovLoginController.actionMain Method
	 * 
	 * @param 
	 * @return void
	 * @throws Exception 
	 */
	public void logLogin() throws Throwable {
 
		String uniqId = "";
		String ip = "";
 
		/* Authenticated  */
        Boolean isAuthenticated = EgovUserDetailsHelper.isAuthenticated();
    	if(isAuthenticated.booleanValue()) {
			LoginVO user = (LoginVO)EgovUserDetailsHelper.getAuthenticatedUser();
			uniqId = user.getUniqId();
			ip = user.getIp();
    	}
 
    	LoginLog loginLog = new LoginLog();
    	loginLog.setLoginId(uniqId);
        loginLog.setLoginIp(ip);
        loginLog.setLoginMthd("I"); // 로그인:I, 로그아웃:O
        loginLog.setErrOccrrAt("N");
        loginLog.setErrorCode("");
        loginLogService.logInsertLoginLog(loginLog);
 
	}
 
	/**
	 * 로그아웃 로그정보를 생성한다.
	 * EgovLoginController.actionLogout Method
	 * 
	 * @param 
	 * @return void
	 * @throws Exception 
	 */
	public void logLogout() throws Throwable {
 
		String uniqId = "";
		String ip = "";
 
		/* Authenticated  */
        Boolean isAuthenticated = EgovUserDetailsHelper.isAuthenticated();
    	if(isAuthenticated.booleanValue()) {
			LoginVO user = (LoginVO)EgovUserDetailsHelper.getAuthenticatedUser();
			uniqId = user.getUniqId();
			ip = user.getIp();
    	}
 
    	LoginLog loginLog = new LoginLog();
    	loginLog.setLoginId(uniqId);
        loginLog.setLoginIp(ip);
        loginLog.setLoginMthd("O"); // 로그인:I, 로그아웃:O
        loginLog.setErrOccrrAt("N");
        loginLog.setErrorCode("");
        loginLogService.logInsertLoginLog(loginLog);
	}
 
}

관련기능

접속로그관리는 접속로그 목록조회, 접속로그 상세조회 기능으로 구분된다.

접속로그 목록조회

비즈니스 규칙

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

관련코드

N/A

관련화면 및 수행매뉴얼

ActionURLController methodQueryID
목록조회/sym/log/clg/SelectLoginLogList.doselectLoginLogInf“LoginLogDAO.selectLoginLogInf”,
“LoginLogDAO.selectLoginLogInfCnt”

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

접속로그 상세조회

비즈니스 규칙

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

관련코드

N/A

관련화면 및 수행메뉴얼

ActionURLController methodQueryID
상세조회/sym/log/clg/InqireLoginLog.doselectLoginLog“LoginLogDAO.selectLoginLog”

참고자료

 
egovframework/com/v2/sym/접속로그관리.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