您的位置:首页 > 产品设计 > UI/UE

${pageContext.request.contextPath} JSP取得绝对路径

2017-10-10 23:54 561 查看
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表达式取出来。 

 <%=request.getContextPath()%>是为了解决相对路径的问题,可返回站点的根路径。

        但不用也可以,比如<a href="<%=request.getContextPath()%>/catalog.jsp">,可以直接用<a href="catalog.jsp">也行,这两个文件是在同一个目录下的。比如你要生成一个文件放在服务器上得一个目录下,可以使用request.getContextPath()+/dir,组成一个完整得目录结构!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  jsp