'sitemesh'에 해당되는 글 2건

  1. 2013.04.17 [siteMesh] 초기 설정 방법 & 설정
  2. 2013.04.15 [SiteMesh] SiteMesh(정의/설정)

sitemesh.war 



0. Library


commons-collections.jar
sitemesh-2.4.1.jar 추가

1. web.xml 설정


<context-param>                                     <!-- SiteMesh 설정 파일인 sitemesh.xml파일의 경로를 지정한다. -->
        <param-name>sitemesh.configfile</param-name>
        <param-value>/WEB-INF/config/sitemesh.xml</param-value>
    </context-param>
    
<filter>                                                    <!-- SiteMesh의 필터를 설정한다.  -->
        <filter-name>sitemesh</filter-name>
        <filter-class>com.opensymphony.module.sitemesh.filter.PageFilter</filter-class>
</filter>
    
 
<filter-mapping>                                         <!-- url 패턴이 .jsp로 들어오면 위의 sitemesh 필터를 실행한다.  -->
        <filter-name>sitemesh</filter-name>
        <url-pattern>*.jsp</url-pattern>
        <dispatcher>REQUEST</dispatcher> <!-- jsp에 대한 요청이 REQUEST,FORWARD 시  sitemesh 필터 실행 -->
        <dispatcher>FORWARD</dispatcher>
</filter-mapping>

2. sitemesh.xml 설정

<sitemesh>
     <!-- decorators.xml 의 위치를 지정 -->
    <property name="decorators-file" value="/WEB-INF/config/decorators.xml"/>
    
    <!-- 아래는 붙여 넣기 하기 -->
    <excludes file="${decorators-file}"/>

    <page-parsers>
        <parser content-type="text/html" class="com.opensymphony.module.sitemesh.parser.HTMLPageParser" />
    </page-parsers>

    <decorator-mappers>

        <mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper">
            <param name="property.1" value="meta.decorator" />
            <param name="property.2" value="decorator" />
        </mapper>

        <mapper class="com.opensymphony.module.sitemesh.mapper.FrameSetDecoratorMapper">
        </mapper>

        <mapper class="com.opensymphony.module.sitemesh.mapper.AgentDecoratorMapper">
            <param name="match.MSIE" value="ie" />
            <param name="match.Mozilla [" value="ns" />
            <param name="match.Opera" value="opera" />
            <param name="match.Lynx" value="lynx" />
        </mapper>

        <mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper">
            <param name="decorator" value="printable" />
            <param name="parameter.name" value="printable" />
            <param name="parameter.value" value="true" />
        </mapper>

        <mapper class="com.opensymphony.module.sitemesh.mapper.RobotDecoratorMapper">
            <param name="decorator" value="robot" />
        </mapper>

        <mapper class="com.opensymphony.module.sitemesh.mapper.ParameterDecoratorMapper">
            <param name="decorator.parameter" value="decorator" />
            <param name="parameter.name" value="confirm" />
            <param name="parameter.value" value="true" />
        </mapper>

        <mapper class="com.opensymphony.module.sitemesh.mapper.FileDecoratorMapper">
        </mapper>

        <mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper">
            <param name="config" value="${decorators-file}" />
        </mapper>

    </decorator-mappers>

</sitemesh>

3. decorators.xml 설정
<?xml version="1.0" encoding="UTF-8"?>

<decorators defaultdir="/decorators">                 <!-- WebContent / decorators라는 폴더를 default directory로 한다.  -->
    <decorator name="main" page="main.jsp">       
        <pattern>/index.jsp</pattern>                     <!-- index.jsp로 url 패턴이 들어오면 main.jsp를 실행한다  -->
    </decorator>
    
    <decorator name="panel" page="panel.jsp"/>
</decorators>


4. main.jsp 에각 모듈 붙여 넣기

<?xml version="1.0" encoding="EUC-KR" ?>
<%@ page language="java" contentType="text/html; charset=EUC-KR" pageEncoding="EUC-KR"%>
<%@ taglib prefix="decorator" uri="http://www.opensymphony.com/sitemesh/decorator" %> <!-- 태그 라이브러리 설정 -->
<%@ taglib prefix="page" uri="http://www.opensymphony.com/sitemesh/page" %>              <!-- 태그 라이브러리 설정 -->
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:f="http://java.sun.com/jsf/core" xmlns:h="http://java.sun.com/jsf/html">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=EUC-KR" />
<title>Insert title here</title>
</head>
<body>
<table>
    
    <tr>
        <td><page:applyDecorator name="panel" page="/include/top.jsp"/></td>   <!--  decorators 에서 panel 이라고 이름 붙여진 곳
                                                                                                                  의 경로에 있는 페이지로 이동하여 설정을 가지고 오고
                                                                                                                  page에 정의된 top.jsp로 이동하여 panel에 선언된 설정
                                                                                                                  부분을 긁어와 가져 온다. -->
    </tr>
    
    <tr>
        <td><decorator:body/></td>                                                                   <!--  index.jsp로 main.jsp에 접근 하였음 으로 
                                                                                                                          index.jsp의 body내용을 가져온다.
                                                                                                                          decorator:title 하면 title의 설정을 가져 온다 -->
    </tr>
    
    <tr>
        <td><page:applyDecorator name="panel" page="/include/bottom.jsp"/></td>
    </tr>
    
</table>
</body>
</html>


5. panel.jsp 설정하기

<%@ page language="java" contentType="text/html; charset=EUC-KR" pageEncoding="EUC-KR"%>
<%@ taglib prefix="decorator" uri="http://www.opensymphony.com/sitemesh/decorator" %>
<%@ taglib prefix="page" uri="http://www.opensymphony.com/sitemesh/page" %>  
<decorator:body/>



'sitemesh' 카테고리의 다른 글

[SiteMesh] SiteMesh(정의/설정)  (0) 2013.04.15
Posted by airlueos
,

1. SiteMesh의 정의

SiteMesh(http://www.sitemesh.org/)는

웹 페이지의 레이아웃을 효율적으로 처리할 수 있도록 도와주는 프레임워크입니다. 

쉽게 말해서 웹사이트의 동일한 상단, 하단, 메뉴 부분을 한곳에서 관리하고 각각의 페이지는 실제 내용만을 관리할 수 있도록 해줍니다.

즉, 상단/하단/메뉴와 같이 반복되는 부분이 각 페이지마다 들어가 있으면 추후 유지보수가 어렵기 때문에 SiteMesh와 같은 프레임워크를 사용하는 것이죠.


웹사이트를 제작하던 초기에는 iframe으로 나누어서 처리하기도 했었구요. SiteMesh 이전에는 include를 활용해서 이런 형태를 구현하기도 했었습니다. 

그러나 iframe은 확장이 어렵고 지원하지 않는 브라우저도 많이 있었네요. 

또한 include는 모든 페이지마다 해당 부분을 삽입해줘야 하는 이슈가 있었죠.

그래서 실제로 SiteMesh를 사용해보면 얼마나 편리한지 알 수 있을 겁니다. 


2. SiteMesh의 처리 방식

SiteMesh는 기본적으로 Java Servlet 환경에서 Filter 형태로 동작하고 있으며 

다음 그림과 같이 Decorator 페이지를 한번 필터링 하는 방식입니다.

기존 페이지는 웹서버가 바로 렌더링된 페이지를 보내주지만 SiteMesh에서는 Decorator 페이지를 한번 더 거치게 된다는 것이죠. 

다음 그림을 보면 SiteMesh의 방식을 좀 더 자세히 이해할 수 있을 것 같네요. 

미리 중간에 있는 이미지와 같이 Decorator를 정의해 둡니다. 

상단의 {title}과 우측의 Body-Content만 각각의 파일들은 가지고 있으면 되는 것이죠.

즉, welcome.jsp와 search.cgi와 같은 파일에는 본문에 들어갈 내용만 가지고 있으면 되는 겁니다. 

이제 Filter를 통해 decorator를 거치면서 하단과 같이 동일한 상단, 하단, 메뉴를 가지고 있는 페이지로 사용자에게 전송됩니다. 

개념은 매우 간단하구요. Java 뿐만 아니라 CGI, PHP, ColdFusion 등에서도 SiteMesh를 활용할 수 있다고 합니다. 



3. SiteMesh의 다운로드 및 설치

먼저 SiteMesh를 다운로드해야 하는데요. 현재 SiteMesh3 알파버전이 소개되고 있습니다. 

SiteMesh2를 사용하려면 여기를 눌러서 sitemesh-2.4.2.jar 파일을 다운로드 하시면 됩니다.


설치하는 방법은 /web/WEB-INF/lib 폴더에 복사하면 됩니다. (여기에서 /web은 프로젝트의 Web Content 폴더를 의미합니다.)

그리고 /web/ 하위에 SiteMesh의 Decorator를 위한 폴더를 하나 만들고 SiteMesh를 적용할 jsp 파일을 하나 생성하면 됩니다. 

/web/decorators/decorator.jsp 

여기에서 decorators 폴더명이나 decorator.xml 파일명은 다른 것을 사용하셔도 됩니다. 

나중에 SiteMesh 설정에서 맞춰서 지정만 해주면 되니까요.. ^^


실제 decorator.jsp에는 다음과 같은 형태로 지정하면 됩니다. 

  1. <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>  
  2. <%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator"%>  
  3. <html>  
  4. <head>  
  5. <decorator:head/>  
  6. </head>  
  7.   
  8. <body>  
  9. Top<br/>  
  10. <decorator:body/><br/>  
  11. Bottom<br/>  
  12. </body>  
  13. </html>  

먼저 tablib를 설정해 주셔야 합니다.

그리고 <decorator:head/> <decorator:body/> 부분이 실제 페이지의 <head>와 <body>의 내용을 넣는 부분이라고 보시면 됩니다. 


4. SiteMesh의 설정

이제 마지막으로 SiteMesh의 설정을 해보도록 하겠습니다. 

3개의 XML 파일을 처리해 줘야 하는데요. 모두 /web/WEB-INF/ 하위에서 작업하면 됩니다. 


1) web.xml

SiteMesh는 Filter 형태로 동작한다고 했으므로 web.xml에 필터 관련 설정을 해줘야 합니다. 

  1. <filter>  
  2.     <filter-name>sitemesh</filter-name>  
  3.     <filter-class>  
  4.         com.opensymphony.module.sitemesh.filter.PageFilter  
  5.     </filter-class>  
  6. </filter>  
  7. <filter-mapping>  
  8.     <filter-name>sitemesh</filter-name>  
  9.     <url-pattern>/*</url-pattern>  
  10. </filter-mapping>  

특별히 수정할 사항 없이 그대로 지정해 주시면 됩니다. 


2) sitemesh.xml

이어서 sitemesh와 관련된 설정을 해줘야 합니다.

이 부분에서도 맨 위의 <property> 부분의 value만 맞춰서 적어주시면 되는데요. 

기본적으로 /web/WEB-INF/ 하위에 모든 설정파일을 둘 경우, 그대로 사용하셔도 됩니다. 

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <sitemesh>  
  3.     <property name="decorators-file" value="/WEB-INF/decorator.xml"/> <!-- 설정 -->  
  4.     <excludes file="${decorators-file}"/>  
  5.   
  6.     <page-parsers>  
  7.         <parser content-type="text/html" class="com.opensymphony.module.sitemesh.parser.HTMLPageParser" />  
  8.     </page-parsers>  
  9.   
  10.     <decorator-mappers>  
  11.   
  12.         <mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper">  
  13.             <param name="property.1" value="meta.decorator" />  
  14.             <param name="property.2" value="decorator" />  
  15.         </mapper>  
  16.   
  17.         <mapper class="com.opensymphony.module.sitemesh.mapper.FrameSetDecoratorMapper">  
  18.         </mapper>  
  19.   
  20.         <mapper class="com.opensymphony.module.sitemesh.mapper.AgentDecoratorMapper">  
  21.             <param name="match.MSIE" value="ie" />  
  22.             <param name="match.Mozilla [" value="ns" />  
  23.             <param name="match.Opera" value="opera" />  
  24.             <param name="match.Lynx" value="lynx" />  
  25.         </mapper>  
  26.   
  27.         <mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper">  
  28.             <param name="decorator" value="printable" />  
  29.             <param name="parameter.name" value="printable" />  
  30.             <param name="parameter.value" value="true" />  
  31.         </mapper>  
  32.   
  33.         <mapper class="com.opensymphony.module.sitemesh.mapper.RobotDecoratorMapper">  
  34.             <param name="decorator" value="robot" />  
  35.         </mapper>  
  36.   
  37.         <mapper class="com.opensymphony.module.sitemesh.mapper.ParameterDecoratorMapper">  
  38.             <param name="decorator.parameter" value="decorator" />  
  39.             <param name="parameter.name" value="confirm" />  
  40.             <param name="parameter.value" value="true" />  
  41.         </mapper>  
  42.   
  43.         <mapper class="com.opensymphony.module.sitemesh.mapper.FileDecoratorMapper">  
  44.         </mapper>  
  45.   
  46.         <mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper">  
  47.             <param name="config" value="${decorators-file}" />  
  48.         </mapper>  
  49.   
  50.     </decorator-mappers>  
  51.   
  52. </sitemesh>  


3) decorator.xml

마지막으로 Decorator를 설정하는 부분을 살펴보도록 하시죠.. 

여기에서는 SiteMesh를 적용할 곳의 패턴들을 지정할 수 있습니다. 

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <decorators defaultdir="/decorators">  
  3.     <decorator name="default" page="decorator.jsp">  
  4.         <pattern>/en/*</pattern>  
  5.         <pattern>/ko/*</pattern>  
  6.     </decorator>  
  7. </decorators>  

위 예에서는 /en과 /ko 하위의 모든 파일에 sitemesh를 적용하라는 것인데요. 

excludes 를 활용해서 특정 파일이나 폴더만 제외할 수도 있습니다. 

그리고 여기에서 사용하는 defaultdir 이나 page는 SiteMesh 다운로드 및 설치에서 생성한 폴더와 파일명이라는 것을 기억해 두시기 바랍니다. 


출처 : http://blog.acronym.co.kr/323

'sitemesh' 카테고리의 다른 글

[siteMesh] 초기 설정 방법 & 설정  (0) 2013.04.17
Posted by airlueos
,