简体   繁体   English

我如何使用@RequestParam批注将表单输入获取到控制器

[英]How do i get form inputs to controller using @RequestParam Annotation

I am trying to get user inputs from form on a Spring Boot application. 我正在尝试从Spring Boot应用程序上的表单获取用户输入。 What do I need to do? 我需要做什么?

I implement a login controller uses a @RequestParam annotation to request the data for validation but getting a result that parameter is not present. 我实现了一个登录控制器,该控制器使用@RequestParam批注来请求数据进行验证,但得到的结果是该参数不存在。

// LoginController.java

@PostMapping(path = "/login")
public String userLogin(@RequestParam("email") String email, 
    @RequestParam("password") String password) {

    // validate username and password
    User user = userRepository.findUserByEmail(email);
    System.out.println(user.getEmail()+" "+user.getPassword());
    if(!(user.getEmail()==email) || !(user.getPassword()==password)){
        logger.info("Invalid user details or not register");
        return "login failed";
    }

    try{
        loginService.login(email, password);
        logger.info("User successfully login");
        return "redirect:dashboard/profile";
    }catch (Exception ex){
        logger.info("",ex);
    }
    return "Successfully logged in ..";
}

Login.html Login.html

<form th:action="@{/login}" method="post" class="form-horizontal" role="form">
    <form:hidden path/>
    <div class="form-group">
        <div class="mb-3">
            <input type="email" class="form-control" name="email" id="email" placeholder="example@gmail.com" required="required">
        </div>
    </div>

    <div class="form-group">
        <div class="mb-3">
            <input type="password" class="form-control" name="password" id="password" placeholder="" required="required">
        </div>
    </div>

    <div class="form-group">
        <div class="col-sm-offset-2 col-sm-10">
            <label>
                <input type="checkbox"> Remember me
            </label>
            <button type="submit" class="btn btn-success">Login</button>
        </div>
    </div>
</form>

I expect the user email and password before he can login but get 我希望用户在登录之前可以收到电子邮件和密码,但得到

2019-07-27 20:30:54.393 WARN 2900 --- [nio-8080-exec-2] .wsmsDefaultHandlerExceptionResolver : Resolved [org.springframework.web.bind.MissingServletRequestParameterException: Required String parameter 'email' is not present] 2019-07-27 20:30:54.393 WARN 2900 --- [nio-8080-exec-2] .wsmsDefaultHandlerExceptionResolver:已解决[org.springframework.web.bind.MissingServletRequestParameterException:必需的字符串参数'email'不存在]

You must send the paramater name from front end : 您必须从前端发送参数名称:

   const payload: FormData = new FormData();
   payload.append("email", emai);
   payload.append("password", password);

The issue because of bad API design and RequestParam mismatch in your URL. 由于API设计错误和URL中的RequestParam不匹配而导致的问题。

Change your API to this: 将您的API更改为此:

@PostMapping(path = "/login") public String userLogin(@RequestBody Map<String, Object> user) {
          String username=user.get("user").toString();
          String password=user.get("password").toString();
}

And your request body JSON should be like this. 您的请求正文JSON应该是这样的。

{
"user":"USER",
"password":"pass5&234rf"
}

This is the JSON payload(body) for the POST request from the client side. 这是来自客户端的POST请求的JSON有效负载(正文)。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM