postforobject 设置代理_如何在spring oauth2上设置代理OAuth2AccessToken请求或如何覆盖OAuth2AccessTokenSupport restTemplat...

这可能不是一个简单的解决方案.但最终设法通过以下代码在oauth请求上设置代理.

注册过滤器

@Override

protected void configure(HttpSecurity http) throws Exception {

// @formatter:off

http.antMatcher("/**")

.authorizeRequests().antMatchers("/webjars/**", "/scripts/**", "/styles/**", "/instances/**", "/#/invalid").permitAll()

.anyRequest().authenticated()

.and().csrf().csrfTokenRepository(csrfTokenRepository())

.and().addFilterAfter(csrfHeaderFilter(), CsrfFilter.class)

.addFilterBefore(oauthFilter(), BasicAuthenticationFilter.class);

// @formatter:on

super.configure(http);

}

验证过滤器

@Autowired

OAuth2ClientContext oauth2ClientContext;

@Autowired

OAuth2ProtectedResourceDetails resource;

@Autowired

ResourceServerProperties resourceServer;

@Autowired

RequestHelper requestHelper;

private Filter oauthFilter() throws KeyManagementException, NoSuchAlgorithmException, KeyStoreException {

OAuth2ClientAuthenticationProcessingFilter oauthFilter = new OAuth2ClientAuthenticationProcessingFilter("/login");

OAuth2RestTemplate oauthTemplate = new OAuth2RestTemplate(resource, oauth2ClientContext);

OAuth2AccessTokenSupport authAccessProvider = new AuthorizationCodeAccessTokenProvider();

// Set request factory for '/oauth/token'

authAccessProvider.setRequestFactory(requestHelper.getRequestFactory());

AccessTokenProvider accessTokenProvider = new AccessTokenProviderChain(Arrays. asList(

(AuthorizationCodeAccessTokenProvider)authAccessProvider));

oauthTemplate.setAccessTokenProvider(accessTokenProvider);

// Set request factory for '/userinfo'

oauthTemplate.setRequestFactory(requestHelper.getRequestFactory());

oauthFilter.setRestTemplate(oauthTemplate);

UserInfoTokenServices userInfoTokenService = new UserInfoTokenServices(resourceServer.getUserInfoUri(), resource.getClientId());

userInfoTokenService.setRestTemplate(oauthTemplate);

oauthFilter.setTokenServices(userInfoTokenService);

return oauthFilter;

}

请求帮助程序代码

@Configuration

public class RequestHelper {

@Value("${proxy.hostname}")

private String proxyHost;

@Value("${proxy.port}")

private int proxyPort;

@Value("${proxy.username}")

private String proxyUser;

@Value("${proxy.password}")

private String proxyPassword;

@Value("${useProxy}")

private boolean useProxyFlag;

@Value("${skipSslValidation}")

private Boolean skipSslValidationFlag;

public HttpComponentsClientHttpRequestFactory getRequestFactory() throws KeyManagementException, NoSuchAlgorithmException, KeyStoreException {

HttpClientBuilder httpClientBuilder = HttpClients.custom();

// Skip SSL validation based on condition

if (skipSslValidationFlag) {

TrustStrategy acceptingTrustStrategy = (X509Certificate[] chain, String authType) -> true;

SSLContext sslContext = org.apache.http.ssl.SSLContexts.custom()

.loadTrustMaterial(null, acceptingTrustStrategy)

.build();

SSLConnectionSocketFactory csf = new SSLConnectionSocketFactory(sslContext);

httpClientBuilder = httpClientBuilder.setSSLSocketFactory(csf);

}

// Set proxy based on condition

if (useProxyFlag) {

CredentialsProvider credentialsProvider = new BasicCredentialsProvider();

credentialsProvider.setCredentials(AuthScope.ANY, new UsernamePasswordCredentials(proxyUser, proxyPassword));

httpClientBuilder = httpClientBuilder.setProxy(new HttpHost(proxyHost, proxyPort));

httpClientBuilder = httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);

}

CloseableHttpClient httpClient = httpClientBuilder.build();

HttpComponentsClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory();

requestFactory.setHttpClient(httpClient);

return requestFactory;

}

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值