缺少请求标头'authToken'调用RestAPI方法

时间:2018-08-08 07:39:44

标签: rest spring-boot resttemplate restful-authentication

我有这个RestAPI方法

let valid = ajv.validate(schema, res);
var detailedErrorMsg = "\n" + ajv.errorsText(ajv.errors, { separator: "\n" }) + "\n";
console.log(detailedErrorMsg);

我从curl叫来

@GetMapping(path = "/menus",
                consumes = "application/json", 
                produces = "application/json")
    public ResponseEntity<List<MenuPriceSummary>> allMenus(HttpServletRequest request,  @RequestHeader(value="Authorization: Bearer") String authToken) {

        String username = jwtTokenUtil.getUsernameFromToken(authToken);
        User user = userService.findByUserName(username);
        return ResponseEntity.ok(menuService.allMenus(user));

    }

但是我得到了这个错误:

curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJsb3Blei5hbnRvbmlvODVAZ21haWwuY29tIiwiZXhwIjoxNTk0MTkzNDYwLCJpYXQiOjE1MzM3MsM0NjB9.9pXvdiRMM5fjE4Ur5nqKvwvRLmNWyn6tY6y5fPXOg_BWEW2sJ8vnrLTXPfiA-Sc6Qk2XTwi6FhlIhFEQKip4aQ"  "http://127.0.0.1:1133/canPeris/api/v1/users/menus"

2 个答案:

答案 0 :(得分:0)

您不能以这种方式使用@RequestHeader。标头中的值被:分割并添加到Map中,因此每个包含:的值都是不可能的。

您将必须将注释更改为@RequestHeader(value="Authorization"),然后从Bearer中删除authToken

答案 1 :(得分:0)

Spring MVC provides annotation @RequestHeader that can be used to map controller parameter to request header value .

    Can you please change your method to 

    @GetMapping(path = "/menus",
                    consumes = "application/json", 
                    produces = "application/json")
    public ResponseEntity<List<MenuPriceSummary>> allMenus(
                @RequestHeader(value="Authorization") String authToken,
                HttpServletRequest request) {

              String username = jwtTokenUtil.getUsernameFromToken(authToken);
            User user = userService.findByUserName(username);
            return ResponseEntity.ok(menuService.allMenus(user));

        }

You can also make use of Interceptors to validate headers so that other rest endpoints in your application can make use of it .