亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微服務(wù)通過Feign調(diào)用進(jìn)行密碼安全認(rèn)證操作

 更新時(shí)間:2021年06月30日 09:58:50   作者:向大海走去  
這篇文章主要介紹了微服務(wù)通過Feign調(diào)用進(jìn)行密碼安全認(rèn)證操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

微服務(wù)通過Feign調(diào)用進(jìn)行密碼安全認(rèn)證

在項(xiàng)目中,微服務(wù)之間的通信也是通過Feign代理的HTTP客戶端通信,為了保護(hù)我們的業(yè)務(wù)微服務(wù)不被其他非法未經(jīng)允許的服務(wù)調(diào)用, 我們要進(jìn)行訪問授權(quán)配置!

Feign是客戶端配置,@FeignClient注解有個(gè)configuation屬性,可以配置我們自定義的配置類,在此類中注入微服務(wù)認(rèn)證攔截器

  /**
     * 訪問微服務(wù)需要密碼
     * @return
     */
    @Bean
    public FeignBasicAuthRequestInterceptor requestInterceptor(){
        System.out.println("------>進(jìn)入微服務(wù)認(rèn)證攔截器");
        return new FeignBasicAuthRequestInterceptor();
    }

feign內(nèi)部有自帶的BasicAuthRequestInterceptor類實(shí)現(xiàn)了RequestInterceptor接口,接收username,password參數(shù),并將此參數(shù)通過apply方法設(shè)置到了請求頭中

public void apply(RequestTemplate template) {
        template.header("Authorization", new String[]{this.headerValue});
    }

由此我們可知,我們可以自定義類實(shí)現(xiàn)RequestInterceptor接口,重寫apply方法,添加我們的認(rèn)證邏輯,也同樣通過RequestTemplate就token設(shè)置到請求頭中!

啟動兩個(gè)微服務(wù),打印日志信息,兩個(gè)微服務(wù)各自的控制臺都打印,證明認(rèn)證攔截器配置成功,通過Spring容器加載成功

那么,既然feign是客戶端配置,那么客戶端只要知道了所需調(diào)用微服務(wù)的rest就可以不配置這個(gè)攔截器也能訪問,上述代碼并沒有達(dá)到保護(hù)業(yè)務(wù)服務(wù)資源的作用,"調(diào)用我必須需要密碼"這一行為應(yīng)該是由微服務(wù)強(qiáng)制要求才是!那么微服務(wù)在什么地方制定這個(gè)規(guī)則呢?

仔細(xì)閱讀BasicAuthRequestInterceptor源碼便知客戶端將密碼設(shè)置到了請求頭中,feign是模擬HTTP請求到微服務(wù)拿取資源,那么微服務(wù)就可以通過配置過濾器來過濾所有經(jīng)過"我"的請求,微服務(wù)在過濾器拿到客戶端請求的header就可以開始我們的認(rèn)證邏輯了!

比較簡單的認(rèn)證就是各自的微服務(wù)通過application.yml配置訪問所需的賬號密碼,將這個(gè)賬號密碼告訴授信用的調(diào)用方,調(diào)用方設(shè)置feign攔截器將賬號密碼注入到header中!也可以進(jìn)行加密傳輸,過濾器再進(jìn)行解密

微服務(wù)過濾器注意對響應(yīng)設(shè)置編碼,否則輸出中文會亂碼

 httpResponse.setCharacterEncoding("UTF-8");
 httpResponse.setContentType("application/json;charset=utf-8");
 PrintWriter print = httpResponse.getWriter();

可以將過濾器抽取在公共類中,否則每個(gè)微服務(wù)都要配一個(gè)過濾器

微服務(wù)之間調(diào)用部分Feign接口忽略認(rèn)證授權(quán)

在SpringSecurity框架基礎(chǔ)之上實(shí)現(xiàn)微服務(wù)之間部分接口忽略認(rèn)證授權(quán).

思路

創(chuàng)建忽略授權(quán)注解

獲取所有被注解的類或者方法

在SpringSecurity框架中忽略授權(quán)

1. 創(chuàng)建忽略授權(quán)注解

@Target({ElementType.TYPE,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AuthIgnore {
}

2. 獲取所有被注解的類或者方法

@Slf4j
@Configuration
public class AuthIgnoreConfig implements InitializingBean { 
    @Autowired
    private ApplicationContext applicationContext; 
    private static final Pattern PATTERN = Pattern.compile("\\{(.*?)\\}");
    private static final String ASTERISK = "*"; 
    @Getter
    @Setter
    private List<String> ignoreUrls = new ArrayList<>(); 
    @Override
    public void afterPropertiesSet(){
        RequestMappingHandlerMapping mapping = applicationContext.getBean(RequestMappingHandlerMapping.class);
        Map<RequestMappingInfo, HandlerMethod> map = mapping.getHandlerMethods();
        map.keySet().forEach(mappingInfo -> {
            HandlerMethod handlerMethod = map.get(mappingInfo);
            AuthIgnore method = AnnotationUtils.findAnnotation(handlerMethod.getMethod(), AuthIgnore.class);
            Optional.ofNullable(method)
                    .ifPresent(authIgnore -> mappingInfo
                            .getPatternsCondition()
                            .getPatterns()
                            .forEach(url -> ignoreUrls.add(ReUtil.replaceAll(url, PATTERN, ASTERISK))));
        });
        Optional.ofNullable(applicationContext.getBeansWithAnnotation(AuthIgnore.class))
                .ifPresent(stringObjectMap -> stringObjectMap.values()
                    .forEach(object -> Arrays.asList(object.getClass().getInterfaces()[0].getDeclaredMethods()).forEach(method -> {
                        List<Annotation> annotations = Arrays.asList(method.getAnnotation(RequestMapping.class), method.getAnnotation(PostMapping.class),
                                method.getAnnotation(GetMapping.class));
                        annotations.forEach(annotation -> {
                            if (ObjectUtil.isNotEmpty(annotation)) {
                                try {
                                    Field field = Proxy.getInvocationHandler(annotation).getClass().getDeclaredField("memberValues");
                                    field.setAccessible(true);
                                    Map valueMap = (Map) field.get(Proxy.getInvocationHandler(annotation));
                                    String[] string = (String[])valueMap.get("value");
                                    ignoreUrls.add(StrUtil.SLASH.concat(ReUtil.replaceAll(string[0], PATTERN, ASTERISK)));
                                } catch (Exception e) {
                                   log.error(e.getMessage(),e);
                                }
                            }
                        });
                    })));
    }
}

實(shí)現(xiàn)InitializingBean接口后,該類初始化的時(shí)候會調(diào)用afterPropertiesSet方法

代碼中的工具類統(tǒng)一使用的hutool工具類

3. 在SpringSecurity框架中忽略授權(quán)

@Override
    public void configure(WebSecurity web) throws Exception {
        web.ignoring().antMatchers("/**/api/**","/v2/**","/actuator/**","doc.html")
                .antMatchers(authIgnoreConfig.getIgnoreUrls().stream().distinct().toArray(String[]::new));
    }

authIgnoreConfig變量為第二步的類,使用@Autowired注解注入進(jìn)來即可

最后

服務(wù)啟動后自動加載所有的@AuthIgnore標(biāo)注的URL給資源服務(wù)設(shè)置為忽略認(rèn)證

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring整合消息隊(duì)列RabbitMQ流程

    Spring整合消息隊(duì)列RabbitMQ流程

    Spring整合RabbitMQ很容易,但是整合的目的是為了使用,那要使用RabbitMQ就要對其有一定的了解,不然容易整成一團(tuán)漿糊。因?yàn)檎f到底,Spring只是在封裝RabbitMQ的API,讓其更容易使用而已,廢話不多說,讓我們一起整它
    2023-03-03
  • 緩存工具類ACache使用方法詳解

    緩存工具類ACache使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了緩存工具類ACache的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • 理解Java面向?qū)ο缶幊淘O(shè)計(jì)

    理解Java面向?qū)ο缶幊淘O(shè)計(jì)

    這篇文章主要介紹了理解Java面向?qū)ο缶幊淘O(shè)計(jì),面向?qū)ο缶幊淌且环N編程思維方式和編碼架構(gòu)。下面詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-01-01
  • java編程中拷貝數(shù)組的方式及相關(guān)問題分析

    java編程中拷貝數(shù)組的方式及相關(guān)問題分析

    這篇文章主要介紹了java編程中拷貝數(shù)組的方式及相關(guān)問題分析,分享了Java中數(shù)組復(fù)制的四種方式,其次對二維數(shù)組的簡單使用有一段代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • Java分代垃圾回收策略原理詳解

    Java分代垃圾回收策略原理詳解

    這篇文章主要介紹了Java分代垃圾回收策略原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • elasticsearch集群cluster主要功能詳細(xì)分析

    elasticsearch集群cluster主要功能詳細(xì)分析

    這篇文章主要為大家介紹了elasticsearch集群cluster主要功能詳細(xì)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • IDEA 去除 mybatis.xml 文件黃色警告的圖文教程

    IDEA 去除 mybatis.xml 文件黃色警告的圖文教程

    這篇文章主要介紹了IDEA 去除 mybatis.xml 文件黃色警告的方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • Spring?Boot對接Oracle數(shù)據(jù)庫具體流程

    Spring?Boot對接Oracle數(shù)據(jù)庫具體流程

    這篇文章主要給大家介紹了關(guān)于Spring?Boot對接Oracle數(shù)據(jù)庫的具體流程,本文將介紹如何在Spring Boot中連接Oracle數(shù)據(jù)庫的基本配置,包括添加依賴、配置數(shù)據(jù)源、配置JPA等,需要的朋友可以參考下
    2023-11-11
  • Java實(shí)現(xiàn)的迷宮游戲

    Java實(shí)現(xiàn)的迷宮游戲

    這篇文章主要介紹了如何用Java實(shí)現(xiàn)一個(gè)迷宮游戲,本倉庫代碼是經(jīng)過eclipse編譯運(yùn)行過的,一般情況下將本倉庫代碼下載下來之后,使用eclipse編譯直接可以運(yùn)行。
    2021-04-04
  • SSH框架網(wǎng)上商城項(xiàng)目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2

    SSH框架網(wǎng)上商城項(xiàng)目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2

    SSH框架網(wǎng)上商城項(xiàng)目第1戰(zhàn)之整合Struts2、Hibernate4.3和Spring4.2,感興趣的小伙伴們可以參考一下
    2016-05-05

最新評論