第十三節(jié) 資源服務(wù)和認證服務(wù)通信,校驗token

由于本項目資源服務(wù)和認證服務(wù)不在同一服務(wù)上纵朋,這里token‘認證使用遠程認證服務(wù)器認證

修改資源服務(wù)器的配置,主要在配置類繼承資源配置ResourceServerConfigurerAdapter的configure方法

1) 設(shè)置RestTemplate笼痛,默認RestTemplate有些格式無法解析,配置相關(guān)解析器

@LoadBalanced
    @Bean
    public RestTemplate restTemplate() {
        //httpRequestFactory()
        RestTemplate restTemplate = new RestTemplate();
        List<HttpMessageConverter<?>> converters = restTemplate.getMessageConverters();
        for (HttpMessageConverter<?> converter : converters) {
            if (converter instanceof MappingJackson2HttpMessageConverter) {
                MappingJackson2HttpMessageConverter jsonConverter = (MappingJackson2HttpMessageConverter) converter;
                jsonConverter.setObjectMapper(new ObjectMapper());
                jsonConverter.setSupportedMediaTypes(ImmutableList.of(new MediaType("application", "json", MappingJackson2HttpMessageConverter.DEFAULT_CHARSET), new MediaType("text", "javascript", MappingJackson2HttpMessageConverter.DEFAULT_CHARSET)));
            }
        }
        return restTemplate;
    }

2) 設(shè)置token解析器牺堰,因為認證服務(wù)使用的為默認解析器,這里保持一致

 @Bean
        public AccessTokenConverter accessTokenConverter() {
        return new DefaultAccessTokenConverter();
    }
  1. 設(shè)置遠程遠程調(diào)用服務(wù)颅围,以及配置
@Override
    public void configure(ResourceServerSecurityConfigurer resources) {
        resources.tokenServices(tokenServices());//.resourceId(SPARKLR_RESOURCE_ID);
    }
  @Bean
  public ResourceServerTokenServices tokenServices() {
        RemoteTokenServices remoteTokenServices = new RemoteTokenServices();
        remoteTokenServices.setCheckTokenEndpointUrl("https://security-service/oauth/check_token");
//這里硬編碼客戶端信息伟葫,服務(wù)端硬編碼保存在內(nèi)存里,生產(chǎn)上請修改
        remoteTokenServices.setClientId("client");
        remoteTokenServices.setClientSecret("password");
      remoteTokenServices.setRestTemplate(restTemplate());
        remoteTokenServices.setAccessTokenConverter(accessTokenConverter());
        return remoteTokenServices;
    }

認證服務(wù)的修改
1) 為了是校驗請求通過院促,認證服務(wù)筏养,修改配置public class OAuth2Config extends AuthorizationServerConfigurerAdapter
增加.checkTokenAccess("permitAll()")

 @Override
    public void configure(AuthorizationServerSecurityConfigurer security) throws Exception {
        security
                // 開啟/oauth/token_key驗證端口無權(quán)限訪問
                .tokenKeyAccess("permitAll()")
                .checkTokenAccess("permitAll()")
                .passwordEncoder(new BCryptPasswordEncoder())
//        請求/oauth/token的,如果配置支持allowFormAuthenticationForClients的常拓,且url中有client_id和client_secret的會走ClientCredentialsTokenEndpointFilter
                .allowFormAuthenticationForClients();
    }

測試如下

  1. 正確攜帶token訪問api-server的接口
圖片.png
  1. 不使用token渐溶、或者錯誤token使用,返回401或者token異常500


    圖片.png

微服務(wù)項目源碼

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末弄抬,一起剝皮案震驚了整個濱河市茎辐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌掂恕,老刑警劉巖拖陆,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異懊亡,居然都是意外死亡依啰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門斋配,熙熙樓的掌柜王于貴愁眉苦臉地迎上來孔飒,“玉大人灌闺,你說我怎么就攤上這事艰争。” “怎么了桂对?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵甩卓,是天一觀的道長。 經(jīng)常有香客問我蕉斜,道長逾柿,這世上最難降的妖魔是什么缀棍? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮机错,結(jié)果婚禮上爬范,老公的妹妹穿的比我還像新娘。我一直安慰自己弱匪,他們只是感情好青瀑,可當(dāng)我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著萧诫,像睡著了一般斥难。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上帘饶,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天哑诊,我揣著相機與錄音,去河邊找鬼及刻。 笑死镀裤,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的提茁。 我是一名探鬼主播淹禾,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼茴扁!你這毒婦竟也來了铃岔?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤峭火,失蹤者是張志新(化名)和其女友劉穎毁习,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體卖丸,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡纺且,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了稍浆。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片载碌。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖衅枫,靈堂內(nèi)的尸體忽然破棺而出嫁艇,到底是詐尸還是另有隱情,我是刑警寧澤弦撩,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布步咪,位于F島的核電站,受9級特大地震影響益楼,放射性物質(zhì)發(fā)生泄漏猾漫。R本人自食惡果不足惜点晴,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望悯周。 院中可真熱鬧粒督,春花似錦、人聲如沸禽翼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽捐康。三九已至仇矾,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間解总,已是汗流浹背贮匕。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留花枫,地道東北人刻盐。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像劳翰,于是被迫代替她去往敵國和親敦锌。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容