symfony - 如何在 symfony 3.4 中阻止表单生成器的字段
问题描述
顺便说一句,我想修改管理员的字段,从管理员是用户这一事实开始。
但我希望管理员只修改某些字段,而不是用户可以拥有的所有字段。我希望管理员只更改他的用户名、密码和电话号码。
但是当我显示所有字段时,即使是那些不需要的字段。这是我的表单生成器:
<?php
namespace Doctix\AdminBundle\Form;
use Doctix\UserBundle\Form\UserType;
use Doctix\UserBundle\Entity\User;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Form\Extension\Core\Type\EmailType;
use Symfony\Component\Form\Extension\Core\Type\PasswordType;
use Symfony\Component\Form\Extension\Core\Type\TelType;
class AdminType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder->add('user', UserType::class);
}
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'Doctix\AdminBundle\Entity\Admin'
));
}
}
而我的观点:
<div class="box_general padding_bottom">
{{ form_start(form,{'attr': {'id': 'form1'}}) }}
{% if form.user.username is defined %}
<div class="form-group">
<label for="inputEmail" class="col-md-2 control-label">Email</label>
<div class="col-md-10">
{{ form_widget(form.user.username, {'attr': {'class': 'form-control','placeholder':'Email'}}) }}
</div>
</div>
{% endif %}
{% if form.user.password is defined %}
<div class="form-group">
<label for="inputPassword" class="col-md-5 control-label">Mot de passe</label>
<div class="col-md-10">
{{ form_widget(form.user.password, {'attr': {'class': 'form-control','placeholder':'Password'}}) }}
</div>
</div>
{% endif %}
{% if form.user.numTel is defined %}
<div class="form-group">
<label for="inputPassword" class="col-md-5 control-label">N° Téléphone</label>
<div class="col-md-10">
{{ form_widget(form.user.numTel, {'attr': {'class': 'form-control','placeholder':'N° Téléphone'}}) }}
</div>
</div>
{% endif %}
{{ form_end(form) }}
</div>
<div class="panel-footer">
<div class="row">
<div class="col-md-offset-3 col-md-3">
<button class="btn btn-success btn-lg" form="form1"> Valider</button>
</div>
<div class="col-md-3">
<a href="{{ path('doctix_admin_users_parametre') }}" class=" btn btn-danger btn-lg">Annuler </a>
</div>
</div>
</div>
这是我的显示图片: 我的页面渲染
在图片上,我只想要前 3 行,而不是底部的以下。并且单击验证时的更改生效。
最后是我的控制器:
public function editprofilAction(Request $request){
$user = $this->getUser();
if($user===null){
throw new NotFoundHttpException('Utilisateur Inexistant');
}
else {
$em = $this->getDoctrine()->getManager();
$repo = $em->getRepository('DoctixAdminBundle:Admin');
$admin = $repo->findOneBy(array(
'user' => $user,
));
$form = $this->createForm('Doctix\AdminBundle\Form\AdminType', $admin);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$admin->getUser()->setSalt('');
$factory = $this->get('security.encoder_factory');
$encoder = $factory->getEncoder($admin->getUser());
$password_encoder = $encoder->encodePassword($admin->getUser()->getPassword(), $admin->getUser()->getSalt());
$admin->getUser()->setPassword($password_encoder);
$admin->getUser()->setRoles(array('ROLE_ADMIN'));
$em->flush();
// creation d'un flash bag pour une notification flash
$request->getSession()->getFlashBag()->add('Notice', 'Profil Modifié avec succés');
// redirection
$url = $this->generateUrl('doctix_admin_users_parametre');
// redirection permanente avec le status http 301 ::)))))
return $this->redirect($url,301);
}else{
return $this->render('DoctixAdminBundle:User:editprofil.html.twig', array(
'form' => $form->createView()
));
}
}
}
非常感谢。
解决方案
默认情况下,Twigform_end()
函数在调用时呈现所有剩余的字段。您也可以避免此设置render_rest
选项为false
{{ form_end(form, {'render_rest': false}) }}
但是,如果UserType::class
在未呈现的其他字段上定义了一些约束,则在调用时表单验证可能会失败$form->isValid()
。在这种情况下,您应该考虑在控制器中进行手动验证。
{{ form_widget(form._token) }}
如果您保持当前的 Twig 实现,那么您还必须通过调用模板来显式加载 CSRF 令牌(默认情况下对每个表单都处于活动状态) 。
推荐阅读
- c# - 通过 ac# 程序在命令提示符下使用其 IP 地址关闭另一个系统?
- javascript - 单击打印按钮页面后重定向到另一个页面javascript
- java - 即使服务器停止,Clinet 也不会停止发送消息
- javascript - 为什么 let 不比 var 慢?
- unity3d - Unity 2D 轨迹渲染器碰撞
- reactjs - React:调用 this.setState() 后不会调用组件的 render()
- android - 使用 android studio kotlin 生成 UI
- python - 无法将我的按钮放在 tkinter 中的指定一侧
- arduino - MacOS High Sierra Arduino Mac 1.8.5 上的 PROGMEM 错误
- python - 数据框 pandas 中有多个带逗号的值