• Struts2牛逼的拦截器,卧槽这才是最牛的核心!


    struts 拦截器

    拦截器简介及简单的拦截器实例

      Struts2拦截器是在访问某个Action或者Action的某个方法,在字段前或者之后实施拦截,并且Struts2拦截器是可以插拔的,拦截器是AOP的一种实现。

    优点:通用功能的封装,提供可重用性。struts-default.xml文件中可以看到拦截器栈basicStack.我们在引用的时候引用的是默认的拦截器栈 <default-interceptor-ref name=”defaultStack”/>我们写一个拦截器的例子:看一下拦截器是如何运行的,首先我们建立一个HelloAction

     1 public class HelloAction extends ActionSupport{
     2     private String name;
     3     public String getName() {
     4         return name;
     5     }
     6     public void setName(String name) {
     7         this.name = name;
     8     }
     9     private static final long serialVersionUID = 1L;
    10     @Override
    11     public String execute() throws Exception {
    12         This.name=”你好,构造器!”;
    13         System.out.println("默认执行了Action的默认方法");
    14         return SUCCESS;
    15     }
    16 }

    之后定义我们自己的拦截器MyInterceptor:

     1 public class Myinterceptor implements Interceptor{
     2     @Override
     3     public void destroy() {
     4         // TODO Auto-generated method stub
     5         System.out.println("拦截器销毁");
     6     }
     7     @Override
     8     public void init() {
     9         // TODO Auto-generated method stub
    10         System.out.println("拦截器初始化");
    11     }
    12     @Override
    13     public String intercept(ActionInvocation invocation) throws Exception {
    14         // TODO Auto-generated method stub
    15         System.out.println("Action之前调用拦截器!");
    16         String result=invocation.invoke();
    17         System.out.println("Action之后调用拦截器!");
    18         return result;
    19     }
    20 }

    result能够返回Action默认方法的调用结果。Struts.xml文件中的配置:

     1 <struts>
     2  <constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>
     3     <package name="manage"  namespace="/" extends="struts-default">
     4     <interceptors>
     5 <interceptor 
     6 name="myInterceptor"         class="com.java1234.Interceptor.Myinterceptor">
     7 </interceptor>
     8     </interceptors>
     9         <global-results>
    10             <result name="error">error.jsp</result>
    11         </global-results>
    12         <action name="hello" class="com.java1234.Action.HelloAction">
    13             <result name="success">success.jsp</result>
    14             <interceptor-ref name="myInterceptor"></interceptor-ref>
    15             <interceptor-ref name="defaultStack"></interceptor-ref>//默认的拦截器是必须的!
    16         </action>
    17     </package>
    18 </struts> 

    Success.jsp核心代码:

    1 <body>
    2 Name:${name }
    3 </body>

    error.jsp代码:

    1 <body>
    2     错误信息:${error } <br/>
    3 </body>

    运行结果显示:

    ① 拦截器首先会被初始化:

     

    ②之后访问http://localhost:8080/Struts2Chap04/hello:

    先访问的是拦截器Myinterceptor------->接着访问HelloAction--------->访问拦截器,根据result的值为success进行模板页面跳转到success.jsp页面。拦截器Myinterceptor中的String result=invocation.invoke();可以获取到Action执行后的结果!出现结果为:

    简单的拦截器实例(登录验证拦截器)

      我们有一个简单功能,就是登录验证,对于登录的用户可以直接访问gril.未登录的用户会跳转到错误页面,需要登录才能由此功能!

    So,我们开始吧:首先是建一个Model,命名为User:

     1 public class User {
     2     private String userName;
     3     private String password;
     4     public String getUserName() {
     5         return userName;
     6     }
     7     public void setUserName(String userName) {
     8         this.userName = userName;
     9     }
    10     public String getPassword() {
    11         return password;
    12     }
    13     public void setPassword(String password) {
    14         this.password = password;
    15     }
    16 }

    service判断,UserService:

    1 public class UserService {
    2     public boolean login(User user){
    3         if("java".equals(user.getUserName())&&"123456".equals(user.getPassword())){
    4             return true;
    5         }else{
    6             return false;
    7         }
    8     }
    9 }

    UserAction:

     1 public class UserAction extends ActionSupport{
     2     private User user;
     3     private UserService userService=new UserService();
     4     private String error;
     5     public User getUser() {
     6         return user;
     7     }
     8     public void setUser(User user) {
     9         this.user = user;
    10     }
    11     public String getError() {
    12         return error;
    13     }
    14     public void setError(String error) {
    15         this.error = error;
    16     }
    17     private static final long serialVersionUID = 1L;
    18     @Override
    19     public String execute() throws Exception {
    20         // TODO Auto-generated method stub
    21         if(userService.login(user)){
    22             ActionContext actionContext=ActionContext.getContext();
    23             Map<String, Object>session=actionContext.getSession();
    24             session.put("currentUser", user);
    25             return SUCCESS;
    26         }else{
    27             this.error="用户名或者密码错误";
    28             return "error";
    29         }
    30     }
    31 }

    配置struts.xml文件:

     1 <struts>
     2 <constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>
     3     <package name="manage"  namespace="/" extends="struts-default">
     4 <interceptors>    
     5 <interceptor name="loginInterceptor" class="com.java1234.Interceptor.Logininterceptor">
     6 </interceptor>
     7 <interceptor-stack name="mystack">
     8     <interceptor-ref name="loginInterceptor"></interceptor-ref>
     9     <interceptor-ref name="defaultStack"></interceptor-ref>
    10 </interceptor-stack>
    11 </interceptors>
    12         
    <default-interceptor-ref name="mystack"></default-interceptor-ref> 

      方法2 直接引用拦截器栈 可以省去<interceptor-ref name="loginInterceptor"></interceptor-ref>

    <interceptor-ref name="defaultStack"></interceptor-ref>这部分代码。
    14 <global-results>
    15         <result name="error">error.jsp</result>
    16     </global-results>
    17     <action name="user" class="com.java1234.Action.UserAction">
    18         <result name="success">success.jsp</result>
    19         <interceptor-ref name="defaultStack"></interceptor-ref>
    20     </action>
    21     <action name="gril" class="com.java1234.Action.GrilAction">
    22         <result name="success">success.jsp</result>
    23         <interceptor-ref name="loginInterceptor"></interceptor-ref>
    24         <interceptor-ref name="defaultStack"></interceptor-ref>

            方法1 直接引用各个拦截器。直接明了                      

    25 </action>
    26     </package>
    27 </struts>

    Success.jsp文件:

    1 <body>
    2     当前登录的用户为:${currentUser.userName } 
    3 </body>

    error.jsp文件

    1 <body>
    2     错误信息:${error } <br/>
    3     <a href="login.jsp">登录</a>
    4 </body>

    Login.jsp文件:

    1 <body>
    2     <form action="user" method="post">
    3         用户名:<input type="text" name="user.userName">&nbsp;&nbsp;
    4         密  码:<input type="password" name="user.password"><br/>
    5                 <input type="submit" value="登录">
    6 </form>
    7 </body>

    根据前端 http://localhost:8080/Struts2Chap04/login.jsp 显示页面:

    输入应户名和密码。这个时候利用user请求,先经过默认拦截器的拦截验证,之后根据action=userstrut.xml文件中的配置action=user 由类UserAction处理 UserAction通过调用UserService来进行登录判断,进而确定是否登录成功?以下两种情况:

    ①用户名为java 密码为 123456 登录成功,跳转到success.jsp,显示登录结果!

     

    ②用户名或者密码错误,登录失败,跳转到error.jsp页面。

     

    GrilAction代码

    1 public class GrilAction extends ActionSupport{
    2     private static final long serialVersionUID = 1L;
    3     @Override
    4     public String execute() throws Exception {
    5         // TODO Auto-generated method stub
    6         System.out.println("看美女!");
    7         return SUCCESS;
    8     }
    9 }

    如果在前端输入http://localhost:8080/Struts2Chap04/gril ,会先进行拦截器的判断,进入到Logininterceptor拦截器的拦截判断中,

    第一步:进入intercept方法。获取到actionContext,之后利用actionContext获取session,之后利用session获取当前用户,根据当前用户是否为空做出以下两个选择:

    currentUser不为空,那么就是说明已经登录了,可以直接进行访问,所以这个时候进入到GrilAction中进行访问。

    currentUser为空,那么就是说明没有登录,就不能直接访问了,这个时候我们获取到request,利用request设置error,并且传递到前端,result设置为error。之后struts.xml根据result进行处理。

    核心代码如下:

     1 ActionContext actionContext=invocation.getInvocationContext();
     2         Map<String, Object> session=actionContext.getSession();
     3         Object currentUser=session.get("currentUser");
     4         String result=null;
     5         if(currentUser!=null){
     6             result=invocation.invoke();
     7         }else{
     8             HttpServletRequest request=(HttpServletRequest)invocation.getInvocationContext().get(ServletActionContext.HTTP_REQUEST);
     9             request.setAttribute("error", "您未登录,请先登录!");
    10             result="error";
    11         }

    拦截器先告一段落,我们还会回来的!

  • 相关阅读:
    [CF1365D] Solve The Maze
    [CF478C] Table Decorations
    [CF466D] Increase Sequence
    [CF449D] Jzzhu and Numbers
    [CF507E] Breaking Good
    [CF337D] Book of Evil
    [CF1253E] Antenna Coverage
    VMware 在 Win10 下开机后死机的解决方案
    [CF1009F] Dominant Indices
    [CF1037E] Trips
  • 原文地址:https://www.cnblogs.com/zyxsblogs/p/10925054.html
Copyright © 2020-2023  润新知