본문 바로가기

Programming/SpringFrameWork

[펌]Spring Framework 따라하기 [5] - include문과 logging 설정

Spring Framework 따라하기 [5] - include문과 logging 설정
Include 문 사용

home.jsp의 첫 3줄은 이미 index.jsp에서도 사용되었거니와 앞으로 만들 거의 모든 jsp파일에서 사용될 것이다. 이와 같이 공통적으로 사용되는 부분을 추출하여 별도의 파일로 저장해두고 이를 각 파일에서 include하여 사용하면 여러가지로 편리한 점이 많다.

/WebContent/WEB-INF/jsp/includeJSTL.jsp 파일을 만든다:

<%@ page session="false"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jstl/fmt_rt" %>

그리고 각 파일에는 다음 코드를 삽입한다:
 
<%@ include file="/WEB-INF/jsp/includeJSTL.jsp" %>

 
Logging

 
다음 파일을 spring framework 패키지에서 찾아 /WebContent/WEB-INF/lib 폴더에 넣는다:
   /lib/log4j/log4j-1.2.13.jar
/lib/jakarta-commons/commons-logging.jar

/WebContent/WEB-INF/log4j.properties 파일을 다음과 같이 만든다:
   
#------------------------------------------------------------------------------  
log4j.rootLogger=INFO, C1, F1
#------------------------------------------------------------------------------  

#------------------------------------------------------------------------------
# console C1  
#------------------------------------------------------------------------------  
log4j.appender.C1=org.apache.log4j.ConsoleAppender

log4j.appender.C1.layout=org.apache.log4j.PatternLayout
log4j.appender.C1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p [%c:%M()] %m %n


#------------------------------------------------------------------------------
# file F1  
#------------------------------------------------------------------------------  
log4j.appender.F1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.F1.DatePattern='.'yyyy-MM-dd
log4j.appender.F1.File=${webapp.root}/WEB-INF/springbloom.log

log4j.appender.F1.layout=org.apache.log4j.PatternLayout
log4j.appender.F1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p [%c:%M()] %m %n

 
이렇게 하면 log파일은 /WEB-INF폴더에 springbloom.log의 이름으로 만들어진다.
/WEB-INF/web.xml 파일에 다음 코드를 추가하여 log4j의 가동을 가능하게 한다.
보통 log4j.properties 파일은 /WEB-INF/classes/폴더에 두었으나 이를 위와 같이 바꾸려면 아래와 같은 코드가 추가되어야 한다. 이렇게 하는 것은 /WEB-INF/classes 폴더는 비즈니스 로직만을 가지는 폴더로 log 설정파일을 여기에 두는 것이 불합리하다고 판단한 때문이다.
   
<context-param>
 <param-name>log4jConfigLocation</param-name>
 <param-value>/WEB-INF/log4j.properties</param-value>
</context-param>

<listener>
 <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>

 
그런데, 실행해보면 warning이 나타난다. 이유는 잘 모르겠지만... 언젠가 해결해야 할 부분이다.