Salesforce的OAuth2RestTemplate给出错误 - HTTP 400错误请求

时间:2018-05-08 02:26:49

标签: spring spring-security oauth-2.0 salesforce oauth2resttemplate

我正在尝试使用OAuth2RestTemplate将Spring Boot与Salesforce集成,但即使凭据正确,它也会给我Access token denied错误。调试后,我发现Salesforce正在发送400个HTTP状态代码。

package com.sentryds.advis.salesforce;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.security.oauth2.client.OAuth2RestTemplate;
import org.springframework.security.oauth2.client.token.grant.password.ResourceOwnerPasswordResourceDetails;
import org.springframework.security.oauth2.common.AuthenticationScheme;

@SpringBootApplication
public class SalesforceApplication {

    public static void main(String[] args) {

        SpringApplication.run(SalesforceApplication.class, args);
        ResourceOwnerPasswordResourceDetails resourceDetails = new ResourceOwnerPasswordResourceDetails();
        resourceDetails.setAuthenticationScheme(AuthenticationScheme.form);
        resourceDetails.setAccessTokenUri("https://test.salesforce.com/services/oauth2/token");
        resourceDetails.setGrantType("password");
        resourceDetails.setClientId("xxxxxxxx");
        resourceDetails.setClientSecret("xxxxxxxx");
        resourceDetails.setUsername("xxxxxxxx");
        resourceDetails.setPassword("xxxxxxxx");
        OAuth2RestTemplate auth2RestTemplate = new OAuth2RestTemplate(resourceDetails);

        try {
            System.out.println(auth2RestTemplate.getAccessToken());
        } catch (Throwable t) {
            System.out.println(t.getMessage());
        }
    }
}

但是,如果我遵循此technique,那么一切正常。我使用OAuth2RestTemplate的唯一原因是它会自动处理令牌刷新。如果没有使用OAuthRestTemplate还有其他方法可以这样做,那么请告诉我。

1 个答案:

答案 0 :(得分:0)

最后我能够解决这个问题。我发布了我的回答,希望能帮助别人。

ResourceOwnerPasswordResourceDetails resource = new ResourceOwnerPasswordResourceDetails();

resource.setAccessTokenUri("https://test.salesforce.com/services/oauth2/token");
resource.setClientId("client_id");
resource.setClientSecret("client_secret");
resource.setClientAuthenticationScheme(AuthenticationScheme.form);
resource.setUsername("username");
resource.setPassword("password");

OAuth2RestTemplate operations = new OAuth2RestTemplate(resource(), new DefaultOAuth2ClientContext(new DefaultAccessTokenRequest()));
operations.getMessageConverters().add(new MappingJackson2HttpMessageConverter()); // Not required if you are not doing any conversion
operations.getMessageConverters().add(new StringHttpMessageConverter()); // Not required if you are not doing any conversion

try {

    System.out.println(auth2RestTemplate.getAccessToken());

} catch (Throwable t) {

    System.out.println(t.getMessage());
}