2)采用绝对路径遇到的问题
随 着不一样的Web应用发布方式,绝对路径的值也不一样。如Web应用发布为MyApp,则路径”/MyApp/images/title.gif”是正确的, 但发布为另外一应用时如MyApp2,这个路径就不对了,也许这个状况比较少,但以default方式发布Web应用时以上绝对路径也不 同:”/images/title.gif”。
二.解决方案
1)采用绝对路径,但为了解决不一样部署方式的差异,在全部非struts标签的路径前加${pageContext.request.contextPath},如原路径为:
”/images/title.gif”,改成
“${pageContext.request.contextPath}/images/title.gif”。
代码” ${pageContext.request.contextPath}”的做用是取出部署的应用程序名,这样无论如何部署,所用路径都是正确的。
缺点:
操做不便,其余工具没法正确解释${pageContext.request.contextPath}
2) 采用相对路径,在每一个JSP文件中加入base标签,如:
<base href="http://${header['host']}${pageContext.request.contextPath}/pages/cust/relation.jsp" />
这样全部的路径均可以使用相对路径。
缺点:
对于被包含的文件依然无效。
真正使用时须要灵活应用1)和2),写出更加健壮的代码。
在使用的时候可使 用${pageContext.request.contextPath},也同时可使 用<%=request.getContextPath()%>达到一样的效果,同时,也能够 将${pageContext.request.contextPath},放入一个JSP文件中,将用C:set放入一个变量中,而后在用的时候用EL 表达式取出来。
- </pre><pre name="code" class="html"><c:set var="ctx" value="${pageContext.request.contextPath}" />