Как проверить два поля пароля с помощью ajax? - PullRequest
15 голосов
/ 20 сентября 2011

Я пытаюсь проверить два поля пароля с помощью JSF, но пока ничего хорошего, я ищу его в Google, но все было о JSF 1.2 и довольно запутанно, я использую JSF 2.0.

Этоэто то, что я делаю до сих пор:

        <h:outputLabel for="password" value="Password:" />
        <h:inputSecret id="password"  value="#{register.user.password}"  >  
            <f:ajax    event="blur"   listener="#{register.validatePassword}" render="m_password" />
        </h:inputSecret>
        <rich:message id="m_password" for="password"/>

        <h:outputLabel for="password_2" value="Password (again):" />
        <h:inputSecret id="password_2"  value="#{register.user.password_2}"  >  
            <f:ajax    event="blur"     listener="#{register.validatePassword}" />
        </h:inputSecret>

Вот как я это мой контроллер:

public void validatePassword() {
    FacesMessage message;

    if (!user.getPassword().equals(user.getPassword_2()) ){
        message = new FacesMessage(FacesMessage.SEVERITY_ERROR, null, "different password");
    }else{
        message = new FacesMessage(FacesMessage.SEVERITY_INFO, null, "ok");
    }

    FacesContext.getCurrentInstance().addMessage("form:password", message);
}

Любая идея, ребята?

Ответы [ 3 ]

19 голосов
/ 21 сентября 2011

Прежде всего, используйте real Validator для проверки ввода.Не делайте этого в методе события действия.

Что касается конкретной проблемы, вам просто нужно указать оба поля в атрибуте execute <f:ajax>, этоа именно по умолчанию только текущий компонент.Если вы присоедините валидатор к первому входу и отправите значение второго входа как <f:attribute>, то вы сможете получить его в валидаторе.Вы можете использовать атрибут binding для привязки компонента к представлению.Таким образом, вы можете передать переданное значение на UIInput#getSubmittedValue().

Вот пример запуска:

<h:outputLabel for="password" value="Password:" />
<h:inputSecret id="password" value="#{bean.password}" required="true">
    <f:validator validatorId="confirmPasswordValidator" />
    <f:attribute name="confirm" value="#{confirmPassword.submittedValue}" />
    <f:ajax event="blur" execute="password confirm" render="m_password" />
</h:inputSecret>
<h:message id="m_password" for="password" />

<h:outputLabel for="confirm" value="Password (again):" />
<h:inputSecret id="confirm" binding="#{confirmPassword}" required="true">
    <f:ajax event="blur" execute="password confirm" render="m_password m_confirm" />
</h:inputSecret>
<h:message id="m_confirm" for="confirm" />

(обратите внимание, что я добавил required="true" к обоим компонентам, а также обратите внимание, что вам не обязательно связывать компонент подтверждения паролязначение свойства управляемого бина, оно все равно там бесполезно)

с этим валидатором

@FacesValidator("confirmPasswordValidator")
public class ConfirmPasswordValidator implements Validator {

    @Override
    public void validate(FacesContext context, UIComponent component, Object value) throws ValidatorException {
        String password = (String) value;
        String confirm = (String) component.getAttributes().get("confirm");

        if (password == null || confirm == null) {
            return; // Just ignore and let required="true" do its job.
        }

        if (!password.equals(confirm)) {
            throw new ValidatorException(new FacesMessage("Passwords are not equal."));
        }
    }

}
0 голосов
/ 29 января 2014

Вы можете использовать Primefaces p: пароль тега. Пожалуйста, смотрите демо пример . Он имеет атрибут match , который должен быть идентификатором подтверждения пароля.

<p:panel header="Match Mode">  
    <p:messages id="messages" showDetail="true" autoUpdate="true"/>  

    <h:panelGrid columns="2" id="matchGrid">                     
                <h:outputLabel for="pass" value="Password " />  
                <p:password id="pass" value="#{passwordBean.password}" match="confirmPass"   required="true"/>  

                <h:outputLabel for="confirmPass" value="Confirm Password " />  
                <p:password id="confirmPass" value="#{passwordBean.confirmPassword}" required="true"/>  
    </h:panelGrid>  

    <p:commandButton id="saveButton" update="matchGrid" value="Save" />  
</p:panel>
0 голосов
/ 21 сентября 2011

С швом 2 у вас есть компонент <s:validateEquality>, и вам не нужно писать код.Для JSF2 у вас есть модули Seam 3, в частности Faces module и проверка формы в перекрестном поле.Пример:

Сначала вы должны использовать тег s:validateForm:

<h:form id="passwordForm">
    <h:inputSecret id="newPassword"
        required="true"
        redisplay="true"
        value="#{passwordController.newPassword}">
    </h:inputSecret>            
    <h:inputSecret id="confirmationPassword"
        value="#{passwordController.confirmPassword}"
        required="true"
        redisplay="true">
    </h:inputSecret>
    <h:commandButton id="submit" value="Submit" action="#{passwordController.submitPassword}" />
    <s:validateForm validatorId="passwordValidator" />
</h:form>

, и соответствующий Валидатор для формы пароля выше будет выглядеть следующим образом:

@FacesValidator("PasswordValidator")
public class PasswordValidator implements Validator
{
   @Inject
   @InputField
   private String newPassword;

   @Inject
   @InputField
   private String confirmPassword;

   @Override
   public void validate(final FacesContext context, final UIComponent comp, final Object values) throws ValidatorException
   {
      if (!confirmPassword.equals(newPassword))
      {
         throw new ValidatorException(new FacesMessage("Passwords do not match!"));
      }
   }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...