1、在Servlet或者Filter中,一次请求结束后一定要return;
比如PrintWrite.write()之后;
HttpServletResponse.sendRedirect()之后;
ServletRequest.getRequestDispatcher().forward(request, response)之后;
FilterChain.doFilter(request, response)之后;
如果在一次请求未结束之后直接处理下一次请求,比如在Filter拦截一个请求中,没有先return,直接doFilter下一个请求,前台ajax则不能进入到succsess回调函数中;
2、ServletRequest.getRequestDispatcher().forward(request, response)进行跳转的时候,会保留request信息,跳转后浏览器上的url会保持原有的地址
3、HttpServletResponse.sendRedirect()【重定向】不会保留request信息;跳转后浏览器上的url会更新地址
可以拼接参数url
4、对于不需要单点登录、不需要在浏览器重启后继续保存会话状态的登录方式,可以将userName:SessionId存在HttpSession中,只要不关闭浏览器,是可以实现登录的【session是客户端第一次访问服务端,服务端为这次对话创建的session,存在服务端,在关闭客户端浏览器后,意味着本次会话结束,则会清理session】
5、对于重定向异常,错误排查,先排查出是前台还是后台的错,比如重定向一个www.baidu.com
6、js 重定向:
window.location.href="http://www.baidu.com";