我正在嘗試使用Sitemesh 2.4.2來裝飾一些帶有導航欄的JSP,並且還將我的CSS引用提取到此裝飾器中。但是,我無法完成工作:根據我在decorators.xml
中設置模式的方式,我只獲取沒有裝飾器的基本JSP或裝飾器(這是<head>
標記的內容,以及<navbar>
我在我的<body>
標記的開頭添加),而沒有來自基本JSP的內容。
我的應用程序使用Glassfish 4作爲應用程序服務器,因此使用Jersey 2.由於我使用的是JSP,因此我使用Jersey作爲過濾器。Sitemesh 2不裝飾我的JSP
這是我web.xml
(我不能完全肯定,如果我需要這個FORWARD調度員)
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<filter>
<filter-name>SiteMeshFilter</filter-name>
<filter-class>com.opensymphony.sitemesh.webapp.SiteMeshFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>SiteMeshFilter</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>FORWARD</dispatcher>
</filter-mapping>
<filter>
<filter-name>jersey</filter-name>
<filter-class>org.glassfish.jersey.servlet.ServletContainer</filter-class>
<init-param>
<param-name>jersey.config.servlet.filter.forwardOn404</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>com.xxx.jersey2.config.CustomResourceConfig</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>jersey</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
我decorators.xml
<?xml version="1.0" encoding="UTF-8"?>
<decorators defaultdir="/WEB-INF/decorators">
<decorator name="main" page="my_navbar.jsp">
<!--<pattern>/jsp/*</pattern>-->
<pattern>/*</pattern>
</decorator>
</decorators>
在這裏,如果我改變模式<pattern>/jsp/*</pattern>
,那麼裝飾者根本不會被包含 - 我只會得到基本的JSP。
通過將模式設置爲<pattern>/*</pattern>
,我得到只有裝飾器,這是,我只得到my_navbar.jsp
的內容。此外,Sitemesh的標籤(例如<decorator:body />
)根本不會被渲染,它們將出現在可從瀏覽器中看到的結果網頁源代碼中。
這是將是裝飾JSP,my_navbar.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Sandbox application</title>
<link rel="stylesheet" href="../../js/jquery-1.12.4.min.js">
<link rel="stylesheet" href="../../css/bootstrap.min.css">
<link rel="stylesheet" href="../../js/bootstrap.min.js">
<decorator:head />
</head>
<body>
<nav class="navbar navbar-light bg-faded">
<ul class="nav navbar-nav">
<li class="nav-item">
<a class="nav-link" href="/sample-jersey2/">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="/sample-jersey2/movies/list/">Movies</a>
</li>
<li class="nav-item">
<a class="nav-link" href="/sample-jersey2/genres/list/">Genres</a>
</li>
</ul>
</nav>
<decorator:body />
</body>
</html>
最後,JSP中我想的一個拿到飾有我的導航欄和樣式
<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>
<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<html>
<head>
<title></title>
</head>
<body>
<h2>Listing Movies</h2>
<table class="table table-striped">
<tr>
<th>Name</th>
<th>Starring</th>
<th>Genre</th>
</tr>
<c:forEach var="item" items="${it.movies}">
<tr>
<td>${item.name}</td>
<td>${item.starring}</td>
<td>${item.genre}</td>
</tr>
</c:forEach>
</table>
</body>
</html>
任何想法對此將不勝感激。
問候