Dove ci sono diversi approcci.
1) Base Bind variabile nel frammento comune:
common.jspf
:
<%@tag language="java" pageEncoding="UTF-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<c:url value="/" var="base"/>
o simili:
<c:set var="base" value="${pageContext.request.contextPath}"/>
e includono frammento in ogni pagina:
<%@include file="base.jspf"%>
<script src="${base}/js/jquery.js"></script>
<link href="${base}/css/bootstrap.css" rel="stylesheet" type="text/css">
<a href="${base}/index.html">Home</a>
2) Utilizzare${pageContext.request.contextPath}
ovunque:
<script src="${pageContext.request.contextPath}/js/jquery.js"></script>
<link href="${pageContext.request.contextPath}/css/bootstrap.css" rel="stylesheet" type="text/css">
<a href="${pageContext.request.contextPath}/index.html">Home</a>
3) è il mio preferito: aggiungere filtro che includono di base per l'attributo:
/src/java/company/project/web/filter/BaseFilter.java
import java.io.IOException;
import javax.servlet.*;
/**
* Make sane JSP, instead of:
* <pre><a href="<c:url value='/my/path/${id}.html'/>">Title</a></pre>
* allow to use:
* <pre><a href="${ctx}/my/path/${id}.html">Title</a></pre>
*/
public class BaseFilter implements Filter {
@Override
public void init(FilterConfig fc) {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
request.setAttribute("base", request.getServletContext().getContextPath());
chain.doFilter(request, response);
}
@Override
public void destroy() { }
}
e registrare che il filtro in web.xml
:
<filter>
<filter-name>BaseFilter</filter-name>
<filter-class>company.project.web.filter.BaseFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>BaseFilter</filter-name>
<url-pattern>*.htm</url-pattern>
<url-pattern>*.json</url-pattern>
</filter-mapping>
e utilizzare la sintassi pulita (come sopra, ma senza necessità di inserire frammenti boilerplate):
<script src="${base}/js/jquery.js"></script>
<link href="${base}/css/bootstrap.css" rel="stylesheet" type="text/css">
<a href="${base}/index.html">Home</a>
NOTA ho impostato attributi aggiuntivi in quel filtro, per esempio per passare dallo sviluppo alla versione minificata di CSS/JS:
private String min;
@Override
public void init(FilterConfig fc) {
min = fc.getServletContext().getInitParameter("min");
if (min == null)
min = fc.getInitParameter("min");
if (min == null)
min = "min";
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
request.setAttribute("ctx", request.getServletContext().getContextPath());
request.setAttribute("min", min);
chain.doFilter(request, response);
}
e corrispondente codice JSP:
<script src="${base}/js/jquery.${min}.js"></script>
<link href="${base}/css/bootstrap.${min}.css" rel="stylesheet" type="text/css">
parametro iniziale min
possono fissare a dev
o min
in esternamente al file WAR in contex descrittore di distribuzione con ripiegare versione minimizzato quando non impostato.
4) Utilizzare uno scriplet:
<a href="<%=request.getContextPath()%>/index.html">Home</a>
'$ {} pageContext.request.contextPath/nextPage.jsp'? Non funzionerà in uscita, ma rende i collegamenti * entro * l'applicazione abbastanza pulita. –
che però non risolve l'obiettivo. il punto è di eseguire l'url attraverso l'intera logica di formattazione dei link in uscita fornita da Tomcat e tutti i filtri installati, come urlrewrite. In questo caso stiamo facendo qualcosa di più complicato dei percorsi assoluti, stavamo riscrivendo file js per includere la versione build per il busting della cache. – JBCP