簡體   English   中英

無法訪問Spring Boot and Jersey應用程序中的某些控制器

[英]Cannot access some controllers in a Spring Boot and Jersey application

我有一個訪問某些控制器的小問題。 當我向/發送請求時,我得到的是HTTP 404, movies路徑也是如此。

package com.emo.server; 


@Configuration
@ComponentScan({"com.emo.server", "com.emo.server.controller"})
@EnableAutoConfiguration
public class App {
    public static void main(String[] args) {
    SpringApplication.run(App.class, args);
}


@Path("/")
public String home() {
    return "Hello World";
}


@Configuration
@EnableResourceServer
protected static class ResourceServer extends ResourceServerConfigurerAdapter {

    @Override
    public void configure(HttpSecurity http) throws Exception {
        // @formatter:off
        http            
            .authorizeRequests().antMatchers("/movies").permitAll()
            .and()
            .authorizeRequests()
            .antMatchers("/test")
            .access("#oauth2.hasScope('read')");
        // @formatter:on
    }

    @Override
    public void configure(ResourceServerSecurityConfigurer resources) throws Exception {
        resources.resourceId("test");
    }

}


@Configuration
@EnableAuthorizationServer
protected static class OAuth2Config extends AuthorizationServerConfigurerAdapter {

    @Autowired
    private AuthenticationManager authenticationManager;

    @Override
    public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {
        endpoints.authenticationManager(authenticationManager);
    }

    @Override
    public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
        // @formatter:off
        clients.inMemory()
                .withClient("my-trusted-client")
                .authorizedGrantTypes("password", "authorization_code", "refresh_token", "implicit")
                .authorities("ROLE_CLIENT", "ROLE_TRUSTED_CLIENT")
                .scopes("read", "write", "trust")
                .resourceIds("test")
                .accessTokenValiditySeconds(60)
                .and()
                .withClient("my-client-with-secret")
                .authorizedGrantTypes("client_credentials", "password")
                .authorities("ROLE_CLIENT")
                .scopes("read")
                .resourceIds("test")
                .secret("secret");
        // @formatter:on
    }

}

MovieController的一部分:

package com.emo.server.controller;

@Component
@Path("/movies")
@Produces(MediaType.APPLICATION_JSON)
public class MovieController {

    private static final Logger LOGGER = LoggerFactory.getLogger(MovieController.class);

    @GET
    @Path("/")
    public Response getMovies() {
        System.out.println("Just a test after ....");
    }

我希望從中獲得一個測試,但是我得到了404。

控制台部分:

> GET / HTTP/1.1
> User-Agent: curl/7.35.0
> Host: localhost:8080
> Accept: */*
> 
< HTTP/1.1 404 Not Found
* Server Apache-Coyote/1.1 is not blacklisted
< Server: Apache-Coyote/1.1
< X-Content-Type-Options: nosniff
< X-XSS-Protection: 1; mode=block
< Cache-Control: no-cache, no-store, max-age=0, must-revalidate
< Pragma: no-cache
< Expires: 0
< X-Frame-Options: DENY
< X-Application-Context: application
< Content-Type: application/json;charset=UTF-8
< Transfer-Encoding: chunked
< Date: Wed, 07 Oct 2015 19:15:20 GMT
< 
* Connection #0 to host localhost left intact
{"timestamp":1444245320491,"status":404,"error":"Not Found","message":"No message available","path":"/"}

我的項目圖片:

在此處輸入圖片說明

我嘗試使用resourceConfig來注冊我的控制器,但是它發生的是同一件事。

我可以訪問一些端點,例如oauth/tokenhealth ,...。我使用spring-boot和jersey作為Java 8的REST框架。

嘗試將您的控制器注釋更改為以下內容:

@Controller
@RequestMapping(value="/movies", produces="application/json)
public class MovieController{

    @RequestMapping(value="/", method=RequestMethod.GET)
    public MyResponseObject getMovies(){
        //you can return a POJO object if you are using a Jackson Mapper
        return new MyResponseObject("foo", "bar");
    }

}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM