未使用路径变量和http请求作为参数调用Spring Rest Controller方法

时间:2018-10-08 02:52:19

标签: spring-mvc spring-boot spring-rest

这是我的控制器方法

@RestController
public class ProfileController {

    @GetMapping("/quiz/{quizId}/identifyfromsixjson")
      @ResponseBody
      UserProfileQuestion playIdentifyFromSix(@PathVariable String quizId, HttpServletRequest request) {
        ... Calling service method  ... here
      }
}

application.properties

server.contextPath=/myproject
spring.h2.console.enabled=true
spring.jpa.hibernate.ddl-auto=update

因此,当我向http://localhost:8080/myproject/identifyfromsixjson/test发出GET请求时,这就是我在邮递员中看到的响应。

{
    "timestamp": "2018-10-08T02:42:14.387+0000",
    "status": 405,
    "error": "Method Not Allowed",
    "message": "Request method 'GET' not supported",
    "path": "/myproject/quiz/test/identifyfromsixjson"
}

启动日志

018-10-08 01:59:32.603  WARN 46035 --- [           main] aWebConfiguration$JpaWebMvcConfiguration : spring.jpa.open-in-view is enabled by default. Therefore, database queries may be performed during view rendering. Explicitly configure spring.jpa.open-in-view to disable this warning
2018-10-08 01:59:32.641  INFO 46035 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/quiz/{quizId}/identifyfromsixjson]}" onto public org.springframework.http.ResponseEntity<com.myproject.model.UserProfileQuestion> com.myproject.controller.ProfileController.fetchUserProfileAndHeadShot(java.lang.String,javax.servlet.http.HttpServletRequest)
2018-10-08 01:59:32.644  INFO 46035 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
2018-10-08 01:59:32.644  INFO 46035 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)
2018-10-08 01:59:32.672  INFO 46035 --- [           main] o.s.w.s.h.BeanNameUrlHandlerMapping      : Mapped URL path [/myproject] onto handler '/myproject'
2018-10-08 01:59:32.678  INFO 46035 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2018-10-08 01:59:32.678  INFO 46035 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]

我在做什么错了?

2 个答案:

答案 0 :(得分:1)

这是您定义的路径:

/quiz/{quizId}/identifyfromsixjson

这是您要测试的路径

/identifyfromsixjson/test

很明显,它们不匹配,这就是为什么您会收到该错误。

您可以执行以下操作:

1。用您定义的路径进行测试:

http://localhost:8080/myproject/quiz/test/identifyfromsixjson

2。更新您的路径定义

@GetMapping("/identifyfromsixjson/{quizId}")
@ResponseBody
UserProfileQuestion playIdentifyFromSix(@PathVariable String quizId,HttpServletRequest request) {
    ... Calling service method  ... here
}

然后用

进行测试

http://localhost:8080/myproject/identifyfromsixjson/test

答案 1 :(得分:0)

好像您要编写一个RestController。用@RestController

注释控制器
    @RestController
    public class QuizController {
        @GetMapping("/identifyfromsixjson/{quizId}")
        @ResponseBody
        UserProfileQuestion playIdentifyFromSix(@PathVariable String quizId, HttpServletRequest request) {
          ... Calling service method  ... here
        }
    }