Флажки Spring MVC Pre Populate - PullRequest
       4

Флажки Spring MVC Pre Populate

5 голосов
/ 09 августа 2011

Первая небольшая справочная информация.Получил довольно стандартное отношение ролей пользователей, где пользователь может иметь много ролей.У меня есть роли, определенные как набор в классе пользователя.Теперь я знаю, что HTML-формы имеют все значения в виде строк, и я пытаюсь получить их, так как мой пользовательский объект Role не работает.Я реализовал initbinder, чтобы преобразовать идентификатор обратно в объект, чтобы я мог извлечь выбранные значения из своих флажков, эта часть работает.

Но я не могу вернуться к другому пути.Я извлекаю пользователя из базы данных, в которой уже есть роли, и хочу предварительно установить флажки ролей всеми ролями, которые есть у пользователя.На основе этого примера:

Пример флажков

Они говорят, что:

form: checkboxes items = "$ {dynamic-list}"path =" property-to-store "

Для нескольких флажков, если значение« path »или« property »равно любому из значений« checkbox - $ {dynamic-list} »,соответствующий флажок будет установлен автоматически.

Моя интерпретация заключается в том, что я должен быть в состоянии передать ему набор всех ролей и определить путь к ролям из объекта User, и он долженсопоставьте их, в результате чего флажок будет предварительно заполнен.

Кажется, что каждый пример имеет значение dynamic-list в виде String [].Ну, это здорово и здорово, но как это работает для пользовательских объектов, которые мы определили как набор?Могу ли я по-прежнему использовать это однострочное определение для флажков или мне нужно также сделать какой-то заголовок привязки данных в представлении?

Вот мой пользователь dto, пользовательский контроллер, пользовательский связыватель форм и страница редактирования пользователя..

Пользователь DTO

@Entity
@Table
public class User extends BaseDto
{
   @Column(updatable = false) @NotBlank
   private String username;

   @Column(name = "encrypted_password") @Size(min = 6, message = "password must be at least 6 characters") @Pattern(regexp = "^\\S*$", message = "invalid character detected")
   private String password;

   @Column(name = "first_name")
   private String firstName;

   @Column(name = "last_name")
   private String lastName;

   @Column @NotNull
   private boolean enabled;

   @Column @Email @NotBlank
   private String email;

   @Transient
   private String confirmPassword;

   @ManyToMany(targetEntity = Role.class, fetch = FetchType.EAGER, cascade = CascadeType.REFRESH) @JoinTable(name = "user_role", joinColumns = @JoinColumn(name = "user_id"),
      inverseJoinColumns = @JoinColumn(name = "role_id"))
   private Set<Role> roles;

   public User()
   {
   }

   public User(final String usernameIn, final String passwordIn, final String firstNameIn, final String lastNameIn, final String emailIn, final boolean enabledIn)
   {
      username = usernameIn;
      password = passwordIn;
      firstName = firstNameIn;
      lastName = lastNameIn;
      email = emailIn;
      enabled = enabledIn;
   }

   public String getUsername()
   {
      return username;
   }

   public void setUsername(final String usernameIn)
   {
      username = usernameIn;
   }

   public String getPassword()
   {
      return password;
   }

   public void setPassword(final String passwordIn)
   {
      password = passwordIn;
   }

   public String getFirstName()
   {
      return firstName;
   }

   public void setFirstName(final String firstNameIn)
   {
      firstName = firstNameIn;
   }

   public String getLastName()
   {
      return lastName;
   }

   public void setLastName(final String lastNameIn)
   {
      lastName = lastNameIn;
   }

   public String getEmail()
   {
      return email;
   }

   public void setEmail(final String emailIn)
   {
      email = emailIn;
   }

   public String getConfirmPassword()
   {
      return confirmPassword;
   }

   public void setConfirmPassword(final String confirmPasswordIn)
   {
      confirmPassword = confirmPasswordIn;
   }

   public boolean isEnabled()
   {
      return enabled;
   }

   public void setEnabled(final boolean enabledIn)
   {
      enabled = enabledIn;
   }

   public Set<Role> getRoles()
   {
      return roles;
   }

   public void setRoles(final Set<Role> rolesIn)
   {
      roles = rolesIn;
   }
}

Контроллер пользователя

@Controller @RequestMapping("/user")
public class UserController
{
   @Autowired private UserService userService;
   @Autowired private UserDao userDao;
   @Autowired private RoleDao roleDao;

   @InitBinder
   public void bindForm(final WebDataBinder binder)
   {
      binder.registerCustomEditor(Set.class, "roles", new CustomFormBinder<RoleDao>(roleDao, Set.class));
   }

   @RequestMapping(method = RequestMethod.GET)
   public String index(final ModelMap modelMap)
   {
      return "/user/index";
   }

   @RequestMapping(value = "/create", method = RequestMethod.GET)
   public String create(final ModelMap modelMap)
   {
      modelMap.addAttribute("userInstance", new User());
      modelMap.addAttribute("validRoles",  new HashSet<Role>(roleDao.findAll()));

      return "/user/create";
   }

   @RequestMapping(value = "/save", method = RequestMethod.POST)
   public String save(final ModelMap modelMap, @Valid @ModelAttribute("userInstance") final User user, final BindingResult bindingResult)
   {
      // TODO move to service validation
      if (user.getPassword() == null || !user.getPassword().equals(user.getConfirmPassword()) )
      {
         bindingResult.addError(new FieldError("userInstance", "password", "password fields must match"));
         bindingResult.addError(new FieldError("userInstance", "confirmPassword", "password fields must match"));
      }
      if (user.getRoles() == null || user.getRoles().isEmpty())
      {
         bindingResult.addError(new FieldError("userInstance", "roles", "Must select at least one role for a User"));
      }
      if (bindingResult.hasErrors())
      {
         modelMap.addAttribute("validRoles",  new HashSet<Role>(roleDao.findAll()));
         return "/user/create";
      }

      userService.save(user);
      return "redirect:/user/list";
   }

   @RequestMapping(value = "/edit/{id}", method = RequestMethod.GET)
   public String edit(@PathVariable final Integer id, final ModelMap modelMap)
   {
      final User user = userDao.find(id);

      if (user != null)
      {
         modelMap.addAttribute("userInstance", user);
         modelMap.addAttribute("validRoles",  new HashSet<Role>(roleDao.findAll()));
         return "/user/edit";
      }
      return "redirect:/user/list";
   }

   @RequestMapping(value = "/edit", method = RequestMethod.GET)
   public String editCurrent(final ModelMap modelMap)
   {
      return edit(userService.getLoggedInUser().getId(), modelMap);
   }

   @RequestMapping(value = "/update", method = RequestMethod.POST)
   public String update(@Valid @ModelAttribute("userInstance") final User user, final BindingResult bindingResult)
   {
      if (bindingResult.hasErrors())
      {
         return "/user/edit";
      }

      userService.save(user);
      return "redirect:/user/list";
   }

   @ModelAttribute("userInstances")
   @RequestMapping(value = "/list", method = RequestMethod.GET)
   public List<User> list()
   {
      return userDao.findAll();
   }
}

Связыватель пользовательской формы

public class CustomFormBinder<T extends GenericDao> extends CustomCollectionEditor
{
   private final T dao;

   private static final Logger LOG = LoggerFactory.getLogger(CustomFormBinder.class);

   public CustomFormBinder(final T daoIn, final Class collectionType)
   {
      super(collectionType, true);
      dao = daoIn;
   }

   @Override
   protected Object convertElement(final Object element)
   {
      try
      {
         // forms should return the id as the itemValue
         return dao.find(Integer.valueOf(element.toString()));
      }
      catch (NumberFormatException e)
      {
         LOG.warn("Unable to convert " + element + " to an integer");
         return null;
      }
   }

}

Вид редактирования пользователя

    <html>
    <head>
        <title>Create User</title>
    </head>
    <body>

    <c:url value="/user/update" var="actionUrl"/>
    <form:form method="post" commandName="userInstance" action="${actionUrl}">
        <h1>Edit User ${userInstance.username}</h1>

        <div>
            <form:label path="username">Username:</form:label>
            <form:input path="username" id="username" readonly="true"/>
        </div>

        <div>
            <form:label path="password">Password:</form:label>
            <form:input path="password" id="password" type="password" readonly="true"/>
            <tag:errorlist path="userInstance.password" cssClass="formError"/>
        </div>

        <div>
            <form:label path="firstName">First Name:</form:label>
            <form:input path="firstName" id="firstName"/>
            <tag:errorlist path="userInstance.firstName" cssClass="formError"/>
        </div>

        <div>
            <form:label path="lastName">Last Name:</form:label>
            <form:input path="lastName" id="lastName"/>
            <tag:errorlist path="userInstance.lastName" cssClass="formError"/>
        </div>

        <div>
            <form:label path="email">Email:</form:label>
            <form:input path="email" id="email" size="30"/>
            <tag:errorlist path="userInstance.email" cssClass="formError"/>
        </div>

        <div>
         **<%--Want to Pre Populate these checkboxed--%>   
<form:checkboxes title="Assigned Roles:" path="roles" id="roles" items="${validRoles}" itemLabel="displayName" itemValue="id" element="div"/>**
            <tag:errorlist path="userInstance.roles" cssClass="formError"/>
        </div>

        <form:hidden path="enabled"/>
        <form:hidden path="id"/>
        <form:hidden path="version"/>

        <div class="submit">
            <input type="submit" value="Update"/>
            <a href="<c:url value='/user/list'/>" class="cancel">Cancel</a>
        </div>
    </form:form>

    </body>
    </html>

1 Ответ

5 голосов
/ 09 августа 2011

Вам нужен правильный реализованный метод равенства для Role!

Если этого недостаточно, взгляните на класс oorg.springframework.web.servlet.tags.form.AbstractCheckedElementTag.В методе void renderFromValue(Object item, Object value, TagWriter tagWriter) устанавливается флаг проверки.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...