我正在尝试使用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>
任何想法对此将不胜感激。
问候