public class org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor extends org.springframework.web.servlet.handler.HandlerInterceptorAdapter
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor
  super_class: org.springframework.web.servlet.handler.HandlerInterceptorAdapter
{
  private java.lang.String[] authorizedRoles;
    descriptor: [Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      org.springframework.lang.Nullable()

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
         0: .line 34
            aload 0 /* this */
            invokespecial org.springframework.web.servlet.handler.HandlerInterceptorAdapter.<init>:()V
            return
        end local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/springframework/web/servlet/handler/UserRoleAuthorizationInterceptor;

  public final void setAuthorizedRoles(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0091) ACC_PUBLIC, ACC_FINAL, ACC_VARARGS
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
        start local 1 // java.lang.String[] authorizedRoles
         0: .line 45
            aload 0 /* this */
            aload 1 /* authorizedRoles */
            putfield org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor.authorizedRoles:[Ljava/lang/String;
         1: .line 46
            return
        end local 1 // java.lang.String[] authorizedRoles
        end local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Lorg/springframework/web/servlet/handler/UserRoleAuthorizationInterceptor;
            0    2     1  authorizedRoles  [Ljava/lang/String;
    MethodParameters:
                 Name  Flags
      authorizedRoles  

  public final boolean preHandle(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, java.lang.Object);
    descriptor: (Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;Ljava/lang/Object;)Z
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=4, locals=8, args_size=4
        start local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
        start local 1 // javax.servlet.http.HttpServletRequest request
        start local 2 // javax.servlet.http.HttpServletResponse response
        start local 3 // java.lang.Object handler
         0: .line 53
            aload 0 /* this */
            getfield org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor.authorizedRoles:[Ljava/lang/String;
            ifnull 7
         1: .line 54
            aload 0 /* this */
            getfield org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor.authorizedRoles:[Ljava/lang/String;
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 6
      StackMap locals: org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor javax.servlet.http.HttpServletRequest javax.servlet.http.HttpServletResponse java.lang.Object top int int java.lang.String[]
      StackMap stack:
         2: aload 7
            iload 5
            aaload
            astore 4 /* role */
        start local 4 // java.lang.String role
         3: .line 55
            aload 1 /* request */
            aload 4 /* role */
            invokeinterface javax.servlet.http.HttpServletRequest.isUserInRole:(Ljava/lang/String;)Z
            ifeq 5
         4: .line 56
            iconst_1
            ireturn
        end local 4 // java.lang.String role
         5: .line 54
      StackMap locals:
      StackMap stack:
            iinc 5 1
      StackMap locals:
      StackMap stack:
         6: iload 5
            iload 6
            if_icmplt 2
         7: .line 60
      StackMap locals: org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor javax.servlet.http.HttpServletRequest javax.servlet.http.HttpServletResponse java.lang.Object
      StackMap stack:
            aload 0 /* this */
            aload 1 /* request */
            aload 2 /* response */
            aload 3 /* handler */
            invokevirtual org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor.handleNotAuthorized:(Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;Ljava/lang/Object;)V
         8: .line 61
            iconst_0
            ireturn
        end local 3 // java.lang.Object handler
        end local 2 // javax.servlet.http.HttpServletResponse response
        end local 1 // javax.servlet.http.HttpServletRequest request
        end local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Lorg/springframework/web/servlet/handler/UserRoleAuthorizationInterceptor;
            0    9     1   request  Ljavax/servlet/http/HttpServletRequest;
            0    9     2  response  Ljavax/servlet/http/HttpServletResponse;
            0    9     3   handler  Ljava/lang/Object;
            3    5     4      role  Ljava/lang/String;
    Exceptions:
      throws javax.servlet.ServletException, java.io.IOException
    MethodParameters:
          Name  Flags
      request   
      response  
      handler   

  protected void handleNotAuthorized(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, java.lang.Object);
    descriptor: (Ljavax/servlet/http/HttpServletRequest;Ljavax/servlet/http/HttpServletResponse;Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
        start local 1 // javax.servlet.http.HttpServletRequest request
        start local 2 // javax.servlet.http.HttpServletResponse response
        start local 3 // java.lang.Object handler
         0: .line 78
            aload 2 /* response */
            sipush 403
            invokeinterface javax.servlet.http.HttpServletResponse.sendError:(I)V
         1: .line 79
            return
        end local 3 // java.lang.Object handler
        end local 2 // javax.servlet.http.HttpServletResponse response
        end local 1 // javax.servlet.http.HttpServletRequest request
        end local 0 // org.springframework.web.servlet.handler.UserRoleAuthorizationInterceptor this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/springframework/web/servlet/handler/UserRoleAuthorizationInterceptor;
            0    2     1   request  Ljavax/servlet/http/HttpServletRequest;
            0    2     2  response  Ljavax/servlet/http/HttpServletResponse;
            0    2     3   handler  Ljava/lang/Object;
    Exceptions:
      throws javax.servlet.ServletException, java.io.IOException
    MethodParameters:
          Name  Flags
      request   
      response  
      handler   
}
SourceFile: "UserRoleAuthorizationInterceptor.java"