第6讲_用拦截器实现访问权限控制.ppt

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第6讲_用拦截器实现访问权限控制

第6讲 用拦截器实现访问权限控制 学习情境1 Struts2自定义拦截器 Struts自定义拦截器步骤(教材P100) 步骤1:建立Struts工程,编写Action和相应的页面 步骤2:自定义一个实现Interceptor接口的类,在intercept方法中实现拦截器逻辑 步骤3:在struts.xml中为指定Action位置添加拦截器配置 步骤4:为避免覆盖掉默认的拦截器,添加配置defaultStack拦截器 学习情境2 Struts2拦截器应用举例 使用Struts拦截器实现页面的权限访问控制 拦截器在相对应的Action运行之前运行,因此可以实现在Action的页面转发之前判断是否有访问权限。 学习情境2 Struts2拦截器应用举例 例:用户成功登录后,有两种不同权限的身份,必须管理员用户才能进入用户管理页面。 分析: 要点1:使用拦截器拦截用户管理页面的进入;页面的进入必须通过action 要点2:因为用户登录是浏览器级别,所以将身份信息存在Session中; 要点3:用户成功登录时,往Session中写入代表用户身份的状态码,以便拦截器来识别。 学习情境2 Struts2拦截器应用举例 步骤1:建立Struts工程,编写LoginAction和相应的登录页面 在LoginAction中,若登录成功,在Session中写入身份标志信息。 If(用户名密码正确) { ActionContext ctx = ActionContext.getContext(); Map session = ctx.getSession(); session.put(username , getUsername()); } 学习情境2 Struts2拦截器应用举例 步骤2:编写管理页面admin.jsp,并为进入此管理界面进行Action配置(此处没有单独写Action,默认使用ActionSupport类) action name=admin result name=admin/admin.jsp/result result name=input/index.jsp/result interceptor-ref name=defaultStack/ interceptor-ref name=mysimple/ /action (蓝色部分暂时不写) 学习情境2 Struts2拦截器应用举例 步骤3:编写登录成功页面success.jsp,在此页面有个用户管理的入口链接。 body success!!! welcome${username } br a href=http://localhost:8080/TestStruts1/admin.action管理入口/a /body 学习情境2 Struts2拦截器应用举例 步骤4:编写拦截器控制权限 拦截器取出Session中存入的状态码,判断用户身份 ActionContext ctx = invocation.getInvocationContext(); Map session = ctx.getSession(); String user = (String) session.get(username); If(user!=nulluser.equals(“admin”)) return admin;//进入管理页面 else{ ctx.put(“tip”, “您没有管理员的权限!”); //可用EL表达式语言取出 return “input”; //返回到登录页面 } 学习情境2 Struts2拦截器应用举例 步骤5:为admin.action配置相关返回参数以及拦截器 action name=admin result name=admin/admin.jsp/result result name=input/index.jsp/result interceptor-ref name=mysimple/ /action Java EE程序设计 * *

文档评论(0)

didala + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档