一般使用filter过滤用户是否登录或者是否有非法字符,如果用户没有登陆或有非法字符则转向登陆页面,这时候可以使用response.sendRedirect("跳转地址")。

但当在页面上使用了iframe后(见下图的布局结构),发现被重定向的只是父页面中的iframe区域,登陆页面内容显示在iframe区域中。说明在过滤器中发送重定向请求时,是在iframe页面发送的。

java代码解决iframe重定向让父级页面跳转_javascript

为了解决这个问题,改变代码实现,具体代码见下面的代码块:

PrintWriter out = response.getWriter();  
out.println("<html>");
out.println("<script>");

out.println("window.open ('"+ rq.getContextPath() +"','_top')");
out.println("</script>");
out.println("</html>");
response.getWriter().print("<script language='javascript'>alert('非法操作!');</script>");

以上方式可以解决在IFrame区域中展示的登录页面。

但是作者测试时又遇到了一个新的问题:就是alert出来的中文内容为乱码(??????)

所以需要设置response的字符编码类型,解决办法:

把response的字符编码类型设置一下,在servlet中加个

response.setCharacterEncoding("GBK");

//GBK或者UTF-8都可以

或者:

String CONTENT_TYPE = "text/html; charset=GBK";

GBK或者UTF-8都可以

response.setContentType(CONTENT_TYPE);

需要注意的是:要在servlet中获取字符打印流 PrintWriter out = response.getWriter();(它的)前面设置编码;

如果读者需要解决同样的问题,希望可以帮到你!

如果读者觉得有需要改进的地方或者有更好的解决方案,请不吝赐教!