【DRP】解决相对路径的问题

  在JSP中如果使用“相对路径”,则有出现问题 例如页面的CSS样式发生改变。主要是因为相对路径是相对于URL请求的地址去寻求资源这就会发生css路径的改变。,客户端跳转与服务器跳转的相对路径是不一样的。服务器的跳转相对于http://localhost:8080/DRP/,客户端的跳转则是相对于页面所在文件夹的位置。

 

举个例子:    

如果register.jsp是通过客户端跳转到edit.jsp,那么edit.jsp里面引用CSS的相对路径是../css/edit.css。register.jsp若通过服务器跳转edit.jsp,那么edit.jsp里css的相对路径就变成了css/personInfo.css,而这个时候edit.jsp页面中其它用到URL的相对路径也会改变,服务器跳转是相对http://localhost:8080/DRP/。那么如何避免相对路径的问题?


方法一:直接使用绝对地址

在JSP页面端,获得本项目的绝对地址(http://localhost:8080/DRP/):代码如下

<%
  String path = request.getContextPath();
  pageContext.setAttribute("basePath",path);
%>
<a href="${pageScope.basePath}/jsp/register.jsp">
 或者

<%  
     String path = request.getContextPath();  
     String basePath = request.getScheme()+ "://" +request.getServerName()+ ":"+request.getServerPort()+path+ "/" ;  
%>
<base href="<%=basePath%>">  


在标签<a>中的href属性中,直接采用${pageScope.basePath} 加上"/jsp/register.jsp",从而构建成一个绝对路径(即:/DRP/jsp/register.jsp)但是这样还是比较麻烦,因为需要在每一个链接的前面都要加上" ${pageScope.basePath}"。


方法二:利用html中的<base>标签

base元素可规定页面中所有链接的基准。(即所有的连接是相对base的。)默认情况下页面中的而连接(CSS JavaScript 图片地址)都是相对于当前页面的地址(即浏览器地址栏中的请求URL)可以使用base标签中href属性来设置所有的”相对基准URL”

创建一个a.jsp放置于test文件夹中,连到error.jsp(省略部分代码)

<body>	
	<a href="error-1.jsp">To Error Page</a>	
</body>
跑一下没有找到页面,希望路径是相对于整个的根路径。添加使用base标签使用-还是不好用

<base href=${pageContext.request.ContextPath}/"

<head>
<!-- base需要放到head中 -->
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<base href="${pageContext.request.scheme }://${pageContext.request.serverName }:${pageContext.request.serverPort }${pageContext.request.contextPath}/">
</head>
<body>	
	<a href="error-1.jsp">To Error Page</a>	
</body>
</html>

评论 24
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值