欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot配置攔截器方式實(shí)例代碼

 更新時(shí)間:2020年04月15日 08:19:45   作者:斗戰(zhàn)圣猿  
在本篇文章里小編給大家分享的是關(guān)于SpringBoot配置攔截器方式實(shí)例代碼,有需要的朋友們可以參考下。

步驟:

1.實(shí)現(xiàn)WebMvcConfigurer配置類

2.實(shí)現(xiàn)攔截器 3

. 把攔截器添加到配置中

4.添加需要攔截的請求

5.添加需要排除的請求

package com.zp.springbootdemo.interceptor;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**
 * 和springmvc的webmvc攔截配置一樣
 * @author zp
 */
@Configuration
public class WebConfigurer implements WebMvcConfigurer {
  /**
   * 攔截器配置
   * @param registry
   */
  @Override
  public void addInterceptors(InterceptorRegistry registry) {
    // addPathPatterns攔截所有請求,excludePathPatterns排除特殊的請求
    //registry.addInterceptor(LoginInterceptor()).addPathPatterns("/**");
    registry.addInterceptor(AuthorityInterceptor()).addPathPatterns("/**");
    //excludePathPatterns 排除的請求
//    registry.addInterceptor(LoginInterceptor()).addPathPatterns("/**").excludePathPatterns("/user/**");
//    registry.addInterceptor(AuthorityInterceptor()).addPathPatterns("/**").excludePathPatterns("/user/**");
  }
  /**
   * 攔截器一
   * @return
   */
  @Bean
  public LoginInterceptor LoginInterceptor() {
    return new LoginInterceptor();
  }
  /**
   * 攔截器二
   * @return
   */
  @Bean
  public AuthorityInterceptor AuthorityInterceptor() {
    return new AuthorityInterceptor();
  }
}

基于URL實(shí)現(xiàn)的攔截器:

package com.zp.springbootdemo.interceptor;

import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class LoginInterceptor extends HandlerInterceptorAdapter {
  /**
   * 在請求處理之前進(jìn)行調(diào)用(Controller方法調(diào)用之前)
   * 基于URL實(shí)現(xiàn)的攔截器
   * @param request
   * @param response
   * @param handler
   * @return
   * @throws Exception
   */
  @Override
  public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    String path = request.getServletPath();
    System.out.println("當(dāng)前請求路徑:"+path);
    System.out.println("=========進(jìn)入攔截器1===================");
    if (path.matches(Const.NO_INTERCEPTOR_PATH)) {
      //不需要的攔截直接過
      System.out.println("=========無需攔截===================");
      return true;
    } else {
      System.out.println("=========開始攔截===================");
      // 這寫你攔截需要干的事兒,比如取緩存,SESSION,權(quán)限判斷等
      String token = request.getParameter("token");
      if(token == null){
        System.out.println("=========攔截完成==================="+false);
        return false;
      }
      System.out.println("=========攔截完成==================="+true);
      return true;
    }
  }
}

關(guān)鍵代碼:path.matches(Const.NO_INTERCEPTOR_PATH 就是基于正則匹配的url。

package com.zp.springbootdemo.interceptor;

/**
 * @author zp
 * @explain 常量類
 */
public class Const {

 public static final String SUCCESS = "SUCCESS";
 public static final String ERROR = "ERROR";
 public static final String FIALL = "FIALL";
 /**********************對象和個體****************************/
 public static final String SESSION_USER = "loginedAgent"; // 用戶對象
 public static final String SESSION_LOGINID = "sessionLoginID"; // 登錄ID
 public static final String SESSION_USERID = "sessionUserID"; // 當(dāng)前用戶對象ID編號

 public static final String SESSION_USERNAME = "sessionUserName"; // 當(dāng)前用戶對象ID編號
 public static final Integer PAGE = 10; // 默認(rèn)分頁數(shù)
 public static final String SESSION_URL = "sessionUrl"; // 被記錄的url
 public static final String SESSION_SECURITY_CODE = "sessionVerifyCode"; // 登錄頁驗(yàn)證碼
 // 時(shí)間 緩存時(shí)間
 public static final int TIMEOUT = 1800;// 秒
 public static final String ON_LOGIN = "/logout.htm";
 public static final String LOGIN_OUT = "/toLogout";
 // 不驗(yàn)證URL anon:不驗(yàn)證/authc:受控制的
 public static final String NO_INTERCEPTOR_PATH =".*/((.css)|(.js)|(images)|(login)|(anon)).*";
}

測試:

請求地址:http://127.0.0.1:8080/user/getUser?token=123

結(jié)果:

 

基于注解的攔截器

①創(chuàng)建注解:

package com.zp.springbootdemo.interceptor;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 在需要登錄驗(yàn)證的Controller的方法上使用此注解
 */
@Target({ElementType.METHOD})// 可用在方法名上
@Retention(RetentionPolicy.RUNTIME)// 運(yùn)行時(shí)有效
public @interface LoginRequired {

}

②創(chuàng)建攔截器:

package com.zp.springbootdemo.interceptor;

import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.lang.reflect.Method;

public class AuthorityInterceptor extends HandlerInterceptorAdapter {

 @Override
 public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
  System.out.println("===============進(jìn)入攔截器2=====================");
  // 如果不是映射到方法直接通過
  if (!(handler instanceof HandlerMethod)) {
   System.out.println("===============無需攔截=====================");
   return true;
  }
  // ①:START 方法注解級攔截器
  HandlerMethod handlerMethod = (HandlerMethod) handler;
  Method method = handlerMethod.getMethod();
  // 判斷接口是否需要登錄
  LoginRequired methodAnnotation = method.getAnnotation(LoginRequired.class);
  // 有 @LoginRequired 注解,需要認(rèn)證
  if (methodAnnotation != null) {
   // 這寫你攔截需要干的事兒,比如取緩存,SESSION,權(quán)限判斷等
   System.out.println("===============開始攔截=====================");
   String token = request.getParameter("token");
   if(token == null){
    System.out.println("=========攔截完成==================="+false);
    return false;
   }
   System.out.println("=========攔截完成==================="+true);
   return true;
  }
  System.out.println("===============無需攔截===================");
  return true;
 }
}

測試接口代碼1:

package com.zp.springbootdemo.system.controller;

import com.zp.springbootdemo.interceptor.LoginRequired;
import com.zp.springbootdemo.system.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.Map;

@RestController
@RequestMapping("/user")
public class UserController {
 @Autowired
 private UserService userService;

 @GetMapping("/getUser")
 //@LoginRequired
 public Map<String,String> getUser(@RequestParam Map<String,String> user){
  return userService.getUser(user);
 }
}
請求地址:

http://127.0.0.1:8080/user/getUser?token=123

結(jié)果:

測試接口代碼2:

package com.zp.springbootdemo.system.controller;

import com.zp.springbootdemo.interceptor.LoginRequired;
import com.zp.springbootdemo.system.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.Map;

@RestController
@RequestMapping("/user")
public class UserController {
 @Autowired
 private UserService userService;

 @GetMapping("/getUser")
 @LoginRequired
 public Map<String,String> getUser(@RequestParam Map<String,String> user){
  return userService.getUser(user);
 }
}
 

請求地址:

http://127.0.0.1:8080/user/getUser?token=123

結(jié)果:

 

到此這篇關(guān)于SpringBoot配置攔截器方式實(shí)例代碼的文章就介紹到這了,更多相關(guān)SpringBoot配置攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java實(shí)現(xiàn)單線程聊天室

    Java實(shí)現(xiàn)單線程聊天室

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)單線程聊天室,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • Mybatis實(shí)現(xiàn)數(shù)據(jù)的增刪改查實(shí)例(CRUD)

    Mybatis實(shí)現(xiàn)數(shù)據(jù)的增刪改查實(shí)例(CRUD)

    本篇文章主要介紹了Mybatis實(shí)現(xiàn)數(shù)據(jù)的增刪改查實(shí)例(CRUD),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • struts2實(shí)現(xiàn)多文件上傳

    struts2實(shí)現(xiàn)多文件上傳

    這篇文章主要為大家詳細(xì)介紹了struts2實(shí)現(xiàn)多文件上傳,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • Java基礎(chǔ)之StringBuffer詳解

    Java基礎(chǔ)之StringBuffer詳解

    這篇文章主要介紹了Java基礎(chǔ)之StringBuffer詳解,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • java搜索無向圖中兩點(diǎn)之間所有路徑的算法

    java搜索無向圖中兩點(diǎn)之間所有路徑的算法

    這篇文章主要介紹了java搜索無向圖中兩點(diǎn)之間所有路徑的算法
    2019-01-01
  • Java 多用戶登錄限制的實(shí)現(xiàn)方法

    Java 多用戶登錄限制的實(shí)現(xiàn)方法

    最近沒有事情做,閑的發(fā)呆,于是寫個東東練練手。這篇文章主要介紹了Java 多用戶登錄限制的實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • C/C++和Java的交互詳解

    C/C++和Java的交互詳解

    本文旨在簡單的介紹一下如何讓java層和C/C++層相互調(diào)用,這里主要是使用了JNI技術(shù),并沒有深究其原理,只是做了個實(shí)現(xiàn),其目的是為后面的學(xué)習(xí)打開一扇窗。
    2016-01-01
  • Java實(shí)現(xiàn)音頻轉(zhuǎn)文本的示例代碼(語音識別)

    Java實(shí)現(xiàn)音頻轉(zhuǎn)文本的示例代碼(語音識別)

    Java中實(shí)現(xiàn)音頻轉(zhuǎn)文本通常涉及使用專門的語音識別服務(wù),本文主要介紹了Java實(shí)現(xiàn)音頻轉(zhuǎn)文本的示例代碼(語音識別),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-05-05
  • 面試初級Java開發(fā)問到Arrays

    面試初級Java開發(fā)問到Arrays

    這篇文章主要介紹了Java Arrays工具類用法,結(jié)合實(shí)例形式分析了java Arrays工具類針對數(shù)組元素修改、復(fù)制、排序等操作使用技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2021-07-07
  • IDEA搭建多模塊的Maven項(xiàng)目方式(相互依賴)

    IDEA搭建多模塊的Maven項(xiàng)目方式(相互依賴)

    這篇文章主要介紹了IDEA搭建多模塊的Maven項(xiàng)目方式(相互依賴),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08

最新評論