gpt4 book ai didi

php - 如果为空,如何使表单忽略密码字段(symfony2 表单)

转载 作者:IT王子 更新时间:2023-10-29 00:05:56 24 4
gpt4 key购买 nike

我的后端有一个简单的用户管理器,我希望能够在不设置新密码/每次都重复旧密码的情况下编辑用户。

现在,如果我在编辑用户时将密码字段留空,symfony2 会提示必须输入密码,当然我在注册新用户时需要此功能,但是当我编辑它们时,我希望如果没有填写密码框,则忽略密码框。

这是如何实现的?

最佳答案

为了别人的引用,我是这样设计的。

我的表单类型:

public function buildForm(FormBuilder $builder, array $options)
{

$builder
->add('username', 'text', array('label' => 'Servernamn '))
->add('plainPassword', 'repeated', array('type' => 'password', 'first_name' => 'Lösenord för server ', 'second_name' => 'Upprepa lösenord för server',));

$builder-> addValidator(new CallbackValidator(function(FormInterface $form){
$username = $form->get('username')->getData();
if (empty($username)) {
$form['username']->addError(new FormError("Du måste ange ett namn för servern"));
}
}));

}

我的更新操作:

public function updateServerAction($id)
{
$em = $this->getDoctrine()->getEntityManager();

$entity = $em->getRepository('BizTVUserBundle:User')->find($id);

if (!$entity) {
throw $this->createNotFoundException('Unable to find Container entity.');
}

$originalPassword = $entity->getPassword();

$editForm = $this->createForm(new editServerType(), $entity);

$request = $this->getRequest();

$editForm->bindRequest($request);

if ($editForm->isValid()) {

$plainPassword = $editForm->get('plainPassword')->getData();
if (!empty($plainPassword)) {
//encode the password
$encoder = $this->container->get('security.encoder_factory')->getEncoder($entity); //get encoder for hashing pwd later
$tempPassword = $encoder->encodePassword($entity->getPassword(), $entity->getSalt());
$entity->setPassword($tempPassword);
}
else {
$entity->setPassword($originalPassword);
}

$em->persist($entity);
$em->flush();

return $this->redirect($this->generateUrl('Server'));
}

因此更新我的用户密码应该设置,否则保留原始密码。

关于php - 如果为空,如何使表单忽略密码字段(symfony2 表单),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11961331/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com