首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Spring MVC:更新现有实体

Spring MVC:更新现有实体
EN

Stack Overflow用户
提问于 2020-02-05 01:11:14
回答 2查看 112关注 0票数 1

实体类

代码语言:javascript
运行
复制
@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    @NotNull
    private String firstName;
    @NotNull
    private String lastName;
    @NotNull
    @Email
    private String email;
    private String country;
    private String state;
    private String roles;
    private String permissions;
    @NotNull
    @Size(min=6)
    private String password;
    private String telNumber;


    public User() {
    }
    public User(String firstName,String lastName,String email,String roles,String permissions,String password) {
    this.firstName=firstName;
    this.lastName=lastName;
    this.email=email;
    this.roles=roles;
    this.permissions=permissions;
    this.password=password;
    }
    public String getCountry() {
        return country;
    }

    public void setCountry(String country) {
        this.country= country;
    }

    public String getState() {
        return state;
    }

    public void setMesto(String state) {
        this.state= state;
    }
    public String getRoles() {
        return roles;
    }

    public List<String> getRolesList(){
        if(this.roles.length()>0){
            return Arrays.asList(this.roles.split(","));
        }
        return new ArrayList<>();
    }
    public List<String> getPermissionsLisst(){
        if(this.permissions.length()>0){
            return Arrays.asList(this.permissions.split(","));
        }
        return new ArrayList<>();
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getFirstName() {
        return firstName;
    }

    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }

    public String getLastName() {
        return lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }


    public void setRoles(String roles) {
        this.roles = roles;
    }


    public void setPermissions(String permissions) {
        this.permissions = permissions;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getTelNumber() {
        return telNumber;
    }

    public void setTelNumber(String telNumber) {
        this.telNumber = telNumber;
    }

这是我的观点

代码语言:javascript
运行
复制
    <div class="udaje container mx-auto text-dark">
<form th:action="@{/admin/useractions}" th:object="${user}" method="post">
    <div class="form-group">
        <label for="firstName" class="form-control-label">First Name</label> <input
            type="text" class="form-control" th:field="*{firstName}" id="firstName" />
        <div class="text text-danger" th:if="${#fields.hasErrors('firstName')}"
             th:errors="*{firstName}"></div>
    </div>
    <div class="form-group">
        <label for="lastName" class="form-control-label">Last Name</label> <input
            type="text" class="form-control" th:field="*{lastName}" id="lastName" />
        <div class="text text-danger" th:if="${#fields.hasErrors('lastName')}"
             th:errors="*{lastName}"></div>
    </div>
    <div class="form-group">
        <label for="email" class="form-control-label">Email</label> <input
            type="text" class="form-control" th:field="*{email}" id="email" />
        <div class="text text-danger" th:if="${#fields.hasErrors('email')}"
             th:errors="*{email}"></div>
    </div>
    <div class="form-group">
        <label class="form-control-label">State</label><input
            type="text" class="form-control" th:field="*{state}" id="state" />
        <div class="text text-danger" th:if="${#fields.hasErrors('state')}"
             th:errors="*{state}"></div>
    </div>
    <div class="form-group">
        <label for="country" class="form-control-label">Country</label> <input
            type="text" class="form-control" th:field="*{mesto}" id="country" />
        <div class="text text-danger" th:if="${#fields.hasErrors('country')}"
             th:errors="*{country}"></div>
    </div>

    <div class="form-group">
        <label for="password" class="form-control-label">Password</label> <input
            type="password" class="form-control" th:field="*{password}" id="password" />
        <div class="text text-danger" th:if="${#fields.hasErrors('password')}"
             th:errors="*{password}"></div>
    </div>
    <div class="text-center">
        <input type="submit" value="Submit" class="btn btn-dark" />
    </div>

</form>

控制器

代码语言:javascript
运行
复制
@Controller
public class UserController {
    @Autowired
    private UserServices userServices;
    private UserRepository userRepository;
    public int roh;
    @GetMapping("/admin/userlist")
    public String userList(Model model,@RequestParam(defaultValue = "") String email){
        model.addAttribute("users",userServices.findByEmailLike(email));
        return "/admin/userlist";
    }
    @RequestMapping("/admin/useractions")
    public String userActions(@RequestParam(value = "id", required = true) Integer id, Model model){
        model.addAttribute("user",userServices.findOne(id));
        return "/admin/useractions";
    }
@PutMapping("/admin/useractions")
public User updateUser(@RequestBody User user) {
    return userServices.update(user);
}

}

您好,我正在寻找使用jpa存储库更新用户的方法。我已经尝试了许多方法,我通过互联网浏览了1/2的情况下,它是接收错误id不存在(就像这种方式

代码语言:javascript
运行
复制
public User update(User user){
        return userRepository.save(user);
    }

),或者它不是在更新用户,而是在创建一个新的用户。我也在使用PasswordEncoder,当我想在密码字段中打印用户密码时,密码字段是空的,可以在字段中键入*吗?感谢你的帮助

EN

Stack Overflow用户

回答已采纳

发布于 2020-02-05 02:19:14

你的代码有各种各样的错误和误解:

将其更改为如下所示:

代码语言:javascript
运行
复制
@Controller
public class UserController {

    @Autowired
    private UserServices userServices;

    @GetMapping("/admin/userlist")
    public String userList(Model model,@RequestParam(defaultValue = "") String email){
        model.addAttribute("users",userServices.findByEmailLike(email));
        return "/admin/userlist";
    }

    @GetMapping("/admin/useractions")
    public String userActions(){
        return "/admin/useractions";
    }

    @PostMapping("/admin/useractions")
    public String updateUser(@ModelAttribute User user) {
        userServices.update(user);

        return "/theNextView";
    }

    @ModelAttribute("user")
    public User getUser(@RequestParam(value = "id", required = false) Integer id) {
        return id !=null ? userServices.findOne(id) : new User();
    }
}

并在您的编辑表单中添加:

<input type="hidden" name="id" value="${user.id}" />

在GET和POST中,如果将requestParam id设置为URL param或隐藏字段,则getUser(...)将使用现有用户填充模型。

在后一种情况下,该现有用户将被传递给POST处理程序,并且提交的表单数据将被绑定到该现有实例。

票数 0
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60062353

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档