【问题标题】:Why does the handler method not get found?为什么找不到处理程序方法?
【发布时间】:2015-10-24 18:06:58
【问题描述】:

我想使用org.springframework.web.bind.annotation.RestController 在我的 GWT WebApplication 之外公开一个简单的 REST API。因此,我在 web.xml 中添加了另一个 servlet,并将其映射到 /app/restapi/*:

<!-- ... -->
<servlet>
    <servlet-name>xsrf</servlet-name>
    <servlet-class>com.google.gwt.user.server.rpc.XsrfTokenServiceServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>xsrf</servlet-name>
    <url-pattern>/app/xsrf</url-pattern>
</servlet-mapping>

<!-- New servlet for my REST API -->
<servlet>
    <servlet-name>mobile-dispatcher</servlet-name>
    <servlet-class>
        org.springframework.web.servlet.DispatcherServlet
    </servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>mobile-dispatcher</servlet-name>
    <url-pattern>/app/restapi/*</url-pattern>
</servlet-mapping>

这是应该处理请求的控制器:

@RestController
@RequestMapping("/app/restapi")
public class RestaurantController {

    class ReturnValue {
        public String str = "1337";
    }

    @ResponseStatus(HttpStatus.OK)
    @RequestMapping(value = "/test", method = RequestMethod.GET, produces = { "application/json" })
    public ReturnValue getTest() {
        return new ReturnValue();
    }
}

问题是请求http://localhost:8080/app/restapi/test 给我的只是:

16:14:22.497 [http-bio-8080-exec-8] DEBUG o.s.web.servlet.DispatcherServlet - DispatcherServlet with name 'mobile-dispatcher' processing GET request for [/app/restapi/test]
16:14:22.497 [http-bio-8080-exec-8] DEBUG o.s.w.s.m.m.a.RequestMappingHandlerMapping - Looking up handler method for path /test
16:14:22.497 [http-bio-8080-exec-8] DEBUG o.s.w.s.m.m.a.RequestMappingHandlerMapping - Did not find handler method for [/test]
16:14:22.497 [http-bio-8080-exec-8] WARN  o.s.web.servlet.PageNotFound - No mapping found for HTTP request with URI [/app/restapi/test] in DispatcherServlet with name 'mobile-dispatcher'
16:14:22.497 [http-bio-8080-exec-8] DEBUG o.s.web.servlet.DispatcherServlet - Successfully completed request

我不知道为什么。那么:我在这里做错了什么,我怎样才能使这项工作按预期进行?

【问题讨论】:

    标签: java rest servlets


    【解决方案1】:

    你像这样配置了你的 servlet 映射

    <servlet-mapping> <servlet-name>mobile-dispatcher</servlet-name> <url-pattern>/app/restapi/*</url-pattern> </servlet-mapping>

    这是您的应用程序的根 URL。当你用RequestMapping("/app/restapi") 配置你的RestController 时,这意味着控制器将监听http://domain/app/restapi/app/restapi。 只需从控制器定义中删除 ("/app/restapi") 就可以了。

    在启动时,Spring MVC 框架应该将它侦听的 URL 映射打印到控制台,您应该在那里看到控制器的映射。

    【讨论】:

      猜你喜欢
      • 2017-09-30
      • 1970-01-01
      • 2016-12-13
      • 1970-01-01
      • 1970-01-01
      • 2018-10-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多