昨天在复习servlet时,在设置过滤器时,发现被拦截器拦截一次就不能登录了,
最开始以为是拦截的路径写错了,后来发现是相对路径没整明白
1.服务器端的地址
服务器端的相对地址指的是相对于你的web应用(项目名字)的地址,这个地址是在服务器端解析的(不同于html和javascript中的相对地址,他们是由客户端 浏览器解析的)也就是说这时候在jsp和servlet中的相对地址应该是相对于你的web应用,即相对于http: //192.168.0.1/webapp/的。
其用到的地方有: forward:servlet中的request.getRequestDispatcher(address); 这个address是在服务器端解析的,所以,你要forward到a.jsp应该这么写:request.getRequestDispatcher (“/user/a.jsp”)这个/相对于当前的web应用webapp,其绝对地址就是:http: //192.168.0.1/webapp/user/a.jsp。
sendRedirect:在jsp中<%response.sendRedirect("/rtccp/user/a.jsp"); %>
2、客户端的地址
所有的html页面中的相对地址都是相对于服务器根目录http://192.168.0.1/)的,而不是(跟目录下的该Web应用的目录)http: //192.168.0.1/webapp/的。 Html中的form表单的action属性的地址应该是相对于服务器根目录(http://192.168.0.1/)的,所以,如果提交到a.jsp 为:action="/webapp/user/a.jsp"或action="<%=request.getContextPath()% >"/user/a.jsp;
提交到servlet为actiom="/webapp/handleservlet"
Javascript也是在客户端解析的,所以其相对路径和form表单一样。
3.2 Servlet中获得当前应用的相对路径和绝对路径
根目录所对应的绝对路径:request.getServletPath();
文件的绝对路径 :request.getSession().getServletContext().getRealPath
(request.getRequestURI())
当前web应用的绝对路径 :servletConfig.getServletContext().getRealPath("/");
(ServletContext对象获得几种方式:
javax.servlet.http.HttpSession.getServletContext()
javax.servlet.jsp.PageContext.getServletContext()
javax.servlet.ServletConfig.getServletContext()
)
出现的问题
不带/的说明,当请求他时,导航栏会把最后的url字段替换成hello
原来是getall,因为没有登录,查询被过滤掉了,
输入
输入账号密码重新登录后,就这样了
所以加上/,发现404,原因就是对于form表单和<a>超链接我都测试了,/相对路径是根目录localhost:8080/
解决方案:
获取当前应用的绝对路径(上下文)