java - Spring Boot 和 OAuth2 : Getting ResourceAccessException: I/O error on POST request for "http://localhost:5555/oauth/token": Connection refused: connect

标签 java rest spring-mvc spring-boot oauth

基于此示例https://github.com/royclarkson/spring-rest-service-oauth我修改了源代码,添加了存储库和其他休息 Controller 。资源和授权服务器在同一应用程序中运行/配置。

我添加了一个带有请求正文的端点“/api/login”(POST):

{"usernamme":"foo", "password":"bar"}

我想在 Controller 调用的服务中获取该用户的访问 token 。此实现如下所示:

Controller

public ResponseEntity<OAuth2AccessToken> login(@RequestBody @Valid final LoginCommand credentials)
        throws LoginFailedException, UnexpectedErrorException {
    try {
        final OAuth2AccessToken token = securityService.authenticate(credentials.getUsername(), credentials.getPassword());
        return ResponseEntity.ok(token);
    } catch (final InvalidGrantException badCredentialExeption) {
        throw new LoginFailedException(badCredentialExeption.getMessage());
    } catch (final Exception e) {
        throw new UnexpectedErrorException(e.getMessage());
    }
}

服务

@Autowired
@Qualifier("OAuth2RestOperations")
private OAuth2RestOperations client;

@Override
public OAuth2AccessToken authenticate(final String username, final String password) {
    final ResourceOwnerPasswordResourceDetails resourceDetails = (ResourceOwnerPasswordResourceDetails) client.getResource();
    resourceDetails.setUsername(username);
    resourceDetails.setPassword(password);
    return client.getAccessToken();
}

其余客户端配置

@Configuration
@Import({ OauthProperties2.class })
@EnableOAuth2Client
public class RestClientConfig {

    @Autowired
    private OauthProperties2 oauth;

    @Bean(name = "OAuth2RestOperations")
    public OAuth2RestOperations restTemplate(final OAuth2ClientContext oauth2ClientContext) {
       return new OAuth2RestTemplate(resource(), oauth2ClientContext);
    }

    @Bean
    public OAuth2ProtectedResourceDetails resource() {
       final ResourceOwnerPasswordResourceDetails resource = new ResourceOwnerPasswordResourceDetails();
       resource.setAccessTokenUri(oauth.getClient().getAccessTokenUri());
       resource.setClientId(oauth.getClient().getClientId());
       resource.setClientSecret(oauth.getClient().getClientSecret());
       resource.setGrantType(oauth.getClient().getGrantType());
       resource.setScope(oauth.getClient().getScope());
       return resource;
    }

}

测试

public class SecurityApiControllerTest extends TestBase {

    @InjectMocks
    private SecurityApiController controller;

    @Test
    public void loginOK() throws Exception {
       final String credentials = FileUtils.readContent("requests/loginOK.json");
    // @formatter:off
        mvc.perform(post("/api/login")
            .contentType(MediaType.APPLICATION_JSON_VALUE)
            .content(credentials))
            .andExpect(status().isOk());
    // @formatter:on
    }

}

测试库

@RunWith(SpringJUnit4ClassRunner.class)
@WebAppConfiguration
@SpringBootTest(classes = Application.class)
public class TestBase {

    @Autowired
    protected WebApplicationContext context;

    @Autowired
    protected FilterChainProxy springSecurityFilterChain;

    protected MockMvc mvc;

    @Before
    public void setUp() {
    MockitoAnnotations.initMocks(this);
        mvc = MockMvcBuilders.webAppContextSetup(context).addFilter(springSecurityFilterChain).build();
    }
 }

运行应用程序时,我可以使用 POSTMAN 等调用端点。在测试过程中,我收到连接被拒绝的信息,如问题标题中所述。我试图找出测试不起作用的原因。有人可以给我提示来解决这个问题吗?

最佳答案

这真是太奇怪了。它有效,因为我已将 TestBase 类更改为:

@RunWith(SpringJUnit4ClassRunner.class)
// @WebAppConfiguration
@ContextConfiguration(classes = Application.class)
@SpringBootTest(webEnvironment = WebEnvironment.DEFINED_PORT)

关于java - Spring Boot 和 OAuth2 : Getting ResourceAccessException: I/O error on POST request for "http://localhost:5555/oauth/token": Connection refused: connect,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43126406/

相关文章:

java - 如何避免使用 Document.createTextNode 对 <、>、& 进行编码

ruby-on-rails - 发送邮件失败时的 HTTP 状态码

java - 将整个应用程序从简单的 Java 迁移到 Spring MVC

api - 如何在 Laravel 4 中构建 REST API 并添加用户

java - 将 JSP 文件包含在另一个 JSP 文件中

java - #oauth2 方法级别的安全表达式

java - 使用 J2ObjC Gradle 插件排除测试

java - 使用dfs的递归树加密方法

java - 将不可修改的 View 发布到内部 map

java - 具有 RESTful 内容提供商的动态网页