纯净且高兴灬爱人0B 金属键盘他祖先
关注数: 0 粉丝数: 1 发帖数: 29 关注贴吧数: 0
今天还发一技术贴!然后出去爬山 何谓页面缓存?简单的说就是,试试IE或者firefox工具栏的前进\后退按钮,就知道了.也就是说,浏览器会先将页面缓存,待下次使用时,就直接从缓存里面取数据,而不重web server重新获取数据.从而减少了server的压力. 但凡事就利就有弊。比如web页面的登陆,如何退出呢?当然在servlet可以用 session.removeAttribute("LogName"); session.invalidate(); 但,仅这样是不完善的。如果用户没有及时将浏览器关闭的话,那么按“后退”按钮,就有可能造成不安全因素了(因为用户并没有真正的退出)。 好在http协议可以自定义缓存页面。示例如下: 一般来说,web页面都有一个登陆按钮。登陆按钮映射servlet或struts action等等。也就是说,登陆动作后,一般都是跳转至主页。所以在sendRedirect或forward动作之前加入清除缓存代码: servlet session.setAttribute("logName", logName);//用户写入session //清除页面 response.setHeader("Pragma","No-cache"); response.setHeader("Cache-Control","no-cache"); response.setHeader("Cache-Control", "no-store"); response.setDateHeader("Expires", 0); //跳转页面 RequestDispatcher requestDispatcher = null; requestDispatcher = request.getRequestDispatcher("index.jsp"); requestDispatcher.forward(request,response); struts2 HttpServletResponse response = ServletActionContext.getResponse(); //清除登陆页面缓存 response.setHeader("Pragma","No-cache"); response.setHeader("Cache-Control","no-cache"); response.setHeader("Cache-Control", "no-store"); response.setDateHeader("Expires", 0);//页面重定位,倒计时。 String URL = "index.jsp"; String content=3+";URL="+URL;//3秒后进入主页 response.setHeader("REFRESH",content); 这样在调用session.invalidate()后,再按IE或firefox退出按钮时,就会出现页面已过期的提示了。 response.setHeader("REFRESH",content); 是实现倒计时跳转页面。
过滤器配置、以前写的列子,贴出来丢丢人 public class PowerFilter implements Filter { @Override public void destroy() {}@Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) request; HttpServletResponse res = (HttpServletResponse) response; // 获得用户请求的URI String path = req.getRequestURI(); //请求地址 String newpath=req.getServerName(); //域名 StringBuffer allpath=new StringBuffer(); allpath.append(newpath).append(path); Object obj=req.getSession().getAttribute("logEmp"); if(obj==null || "".equals(obj)){ res.sendRedirect("http://tieba.baidu.com/mo/q/checkurl?url=http%3A%2F%2Fmgr.3weidu.com%2Fbsm%2Fadmin_login.jsp&urlrefer=7b635ed215ed5d9b0a7bd1b10c079461"); return; } //检测权限 StringBuffer result=new StringBuffer(); AdminEmployee emp=(AdminEmployee)obj; //超级管理员身份 String adminstr=req.getSession().getAttribute("isadmin").toString(); if("yes".equals(adminstr)){ } //普通会员身份 if("no".equals(adminstr)){ List<ResourcePowers> hisAllPowers; try { hisAllPowers = HasPower.powersResoures(emp.getEmpNumber(), emp.getPositionID(), 1002); List<PowerResource> allPowers=AllPowerResource.getGrantResource(); //有操作权限 List<String> vlist=new ArrayList<String>(); if(hisAllPowers.size()>0){ for (int i = 0; i < hisAllPowers.size(); i++) { vlist.add(hisAllPowers.get(i).getResourceURL()); } } for (int i = 0; i < vlist.size(); i++) { String nowStr=vlist.get(i); if(!vlist.contains(nowStr)){ vlist.add(nowStr); } } //筛选没有的权限 for (int i = 0; i < allPowers.size(); i++) { int count=0; for (int j = 0; j < vlist.size(); j++) { if(allPowers.get(i).getResourceURL().equals(vlist.get(j))){ count++; break; } } if(count==0){ //不属于该用户的权限 if("".equals(result.toString())){ result.append(allPowers.get(i).getResourceURL()); }else{ result.append(",").append(allPowers.get(i).getResourceURL()); } } } String powerResult=result.toString(); if (powerResult.contains(path)) { req.setAttribute("info", "您无此操作权限-->返回"); res.sendRedirect("/bsm/jsp/publicjsp/nowpower.jsp"); return; } /*String[] nowPowerArry=powerResult.split(","); for (String str : nowPowerArry) { if(path.equals(str)){ req.setAttribute("info", "您无此操作权限-->返回"); res.sendRedirect("/bsm/jsp/publicjsp/nowpower.jsp"); return; } }*/ } catch (Exception e) { e.printStackTrace(); } } }@Override public void init(FilterConfig config) throws ServletException {}} xml配置 <!--后台权限过滤器 开始 --> <filter> <filter-name>WebPowerFilter</filter-name> <filter-class>com.threeweidu.pepos.util.LogiPowerFilter</filter-class> </filter> <filter-mapping> <filter-name>WebPowerFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!--后台权限过滤器 结束 -->
jsp五种跳转方式 1. RequestDispatcher.forward() 是在服务器端起作用,当使用forward()时,Servlet engine传递HTTP请求从当前的Servlet or JSP到另外一个Servlet,JSP 或普通HTML文件,也即你的form提交至a.jsp,在a.jsp用到了forward()重定向至b.jsp,此时form提交的所有信息在 b.jsp都可以获得,参数自动传递. 但forward()无法重定向至有frame的jsp文件,可以重定向至有frame的html文件,同时forward()无法在后面带参数传递,比如servlet?name=frank,这样不行,可以程序内通过response.setAttribute("name",name)来传至下一个页面。重定向后浏览器地址栏URL不变。例:在servlet中进行重定向 public void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{  response.setContentType("text/html; charset=gb2312");  ServletContext sc = getServletContext();  RequestDispatcher rd = null;  rd = sc.getRequestDispatcher("/index.jsp"); //定向的页面  rd.forward(request, response);} 通常在servlet中使用,不在jsp中使用。 2. response.sendRedirect() 是在用户的浏览器端工作,sendRedirect()可以带参数传递,比如servlet?name=frank传至下个页面,同时它可以重定向至不同的主机上,sendRedirect()可以重定向有frame.的jsp文件. 重定向后在浏览器地址栏上会出现重定向页面的URL 例:在servlet中重定向 public void doPost(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException{  response.setContentType("text/html; charset=gb2312");  response.sendRedirect("/index.jsp");} 由于response是jsp页面中的隐含对象,故在jsp页面中可以用response.sendRedirect()直接实现重定位。 注意: (1) 使用response.sendRedirect时,前面不能有HTML输出;这并不是绝对的,不能有HTML输出其实是指不能有HTML被送到了浏览器。事实上现在的server都有cache机制,一般在8K(我是说 JSP SERVER),这就意味着,除非你关闭了cache,或者你使用了out.flush()强制刷新,那么在使用sendRedirect之前,有少量的HTML输出也是允许的。 (2) response.sendRedirect之后,应该紧跟一句return。我们已经知道response.sendRedirect是通过浏览器来做转向的,所以只有在页面处理完成后,才会有实际的动作。既然你已经要做转向了,那么后的输出还有什么意义呢?而且有可能会因为后面的输出导致转向失败。 比较: (1) Dispatcher.forward()是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址; (2) response.sendRedirect()则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。这样,从浏览器的地址栏中可以看到跳转后的链接地址。前者更加高效,在前者可以满足需要时,尽量使用RequestDispatcher.forward()方法。注:在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使用HttpServletResponse.sendRequest()方法。 3. <jsp:forward page="" /> 它的底层部分是由RequestDispatcher来实现的,因此它带有RequestDispatcher.forward()方法的印记。 如果在之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意。 另外要注意:它不能改变浏览器地址,刷新的话会导致重复提交 4. 修改HTTP header的Location属性来重定向 通过设置直接修改地址栏来实现页面的重定向。 jsp文件代码如下: <% response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY); String newLocn = "/newpath/jsa.jsp"; response.setHeader("Location",newLocn);%> 5. JSP中实现在某页面停留若干秒后,自动重定向到另一页面 在html文件中,下面的代码: <meta http-equiv="refresh" content="300; url=target.jsp"> 它的含义:在5分钟之后正在浏览的页面将会自动变为target.html这一页。代码中300为刷新的延迟时间,以秒为单位。targer.html为你想转向的目标页,若为本页则为自动刷新本页。 由上可知,可以通过setHeader来实现某页面停留若干秒后,自动重定向到另一页面。 关键代码: String content=stayTime+";URL="+URL;response.setHeader("REFRESH",content);
1 下一页