一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 微服務通過Feign調用進行密碼安全認證操作

微服務通過Feign調用進行密碼安全認證操作

2021-09-22 00:47向大海走去 Java教程

這篇文章主要介紹了微服務通過Feign調用進行密碼安全認證操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

微服務通過Feign調用進行密碼安全認證

在項目中,微服務之間的通信也是通過Feign代理的HTTP客戶端通信,為了保護我們的業務微服務不被其他非法未經允許的服務調用, 我們要進行訪問授權配置!

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

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

feign內部有自帶的BasicAuthRequestInterceptor類實現了RequestInterceptor接口,接收username,password參數,并將此參數通過apply方法設置到了請求頭中

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

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

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

微服務通過Feign調用進行密碼安全認證操作

微服務通過Feign調用進行密碼安全認證操作

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

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

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

微服務過濾器注意對響應設置編碼,否則輸出中文會亂碼

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

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

微服務之間調用部分Feign接口忽略認證授權

在SpringSecurity框架基礎之上實現微服務之間部分接口忽略認證授權.

思路

創建忽略授權注解

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

在SpringSecurity框架中忽略授權

1. 創建忽略授權注解

@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);
                                }
                            }
                        });
                    })));
    }
}

實現InitializingBean接口后,該類初始化的時候會調用afterPropertiesSet方法

代碼中的工具類統一使用的hutool工具類

3. 在SpringSecurity框架中忽略授權

@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注解注入進來即可

最后

服務啟動后自動加載所有的@AuthIgnore標注的URL給資源服務設置為忽略認證

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/m0_37268363/article/details/79856424

延伸 · 閱讀

精彩推薦
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7472021-02-04
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
主站蜘蛛池模板: 国产精品 色 | 处女呦呦 | 深夜激情网 | 日韩欧美一区二区三区免费观看 | 亚州成人 | 国产一级黄色网 | 欧美人成绝费网站色www吃脚 | 国产欧美日韩专区毛茸茸 | 欧美老骚| 99热99在线 | 婚前试爱全集免费观看 | 日韩一品在线播放视频一品免费 | 牛牛影院成人免费网页 | 亚洲性69影视 | 欧美日韩中文国产一区二区三区 | 欧美精品黑人巨大在线播放 | 污影院| 恩不要好大好硬好爽3p | 久久精麻豆亚洲AV国产品 | 免费波多野结衣庭教师 | 日本福利网 | 日韩资源 | 亚欧综合 | 日韩激情视频在线观看 | 99在线视频观看 | 草久久网| 特级毛片全部免费播放器 | 奇米影视在线视频 | 91久久精品青青草原伊人 | 日本一区二区精品88 | 国产一区二区三区在线观看视频 | 久久久精品免费免费直播 | 成年人视频在线免费观看 | 美女林柏欣21p人体之仓之梦 | 欧美极品brazzers 高清 | 末发育xxxxx仙踪林 | 热99re久久精品国产首页 | 久久AV国产麻豆HD真实 | 婷婷伊人综合亚洲综合网 | 精品一区视频 | 91庥豆果冻天美精东蜜桃传媒 |