最近做Struts2项目,做登陆验证的拦截器时遇到一个小问题:
我在我的一个a.jsp中写了这么一句:
parent.location.href("login.jsp");
但是当我的a.jsp在webRoot或者和我的login.jsp在同一级目录下时,就没有问题;
但是如果我的a.jsp在a/a.jsp,login.jsp在webRoot下时,此时url为http://localhost:xxxx/SSM/a/a.jsp时,
执行完parent.location.href("login.jsp");我期望的url会访问到我SSM/login.jsp;
但是结果url是SSM/a/login.jsp;即使我在a.jsp中写了
<span style="font-size:14px;"><%@ page language="java" contentType="text/html" pageEncoding="UTF-8"%>
<%
<span style="white-space:pre"> </span>String path = request.getContextPath();
<span style="white-space:pre"> </span>String basePath = request.getScheme() + "://"
<span style="white-space:pre"> </span>+ request.getServerName() + ":" + request.getServerPort()
<span style="white-space:pre"> </span>+ path + "/";
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<base href="<%=basePath%>"></span>
也没有用,我记得其他页面中如果指定了basePath后,页面中所有用的相对路径的地方,都会自动的是相对于basePath根路径了(类似绝对路径)。
但是感觉这个location.href好像丝毫不起作用。
同时在jsp中,我们知道相对路径是相对于客户端url的路径,而不是相对于服务器的路径的。
“/”是表示web的根路径,即tomcat下;如果在jsp中庸parent.location.href("/login.jsp");则会定位到tomcat下的index.jsp中,
这也是我们不希望的,所有只有使用终极方式绝对路径
即:parent.location.href("${basePath}index.jsp");
同时这种方式也避免了对于不同浏览器的兼容问题,因为不同的client解析location.href的方式不同,出来的路径也不一样。
但是用这种方式就避免了那些问题。