Форма только с токеном CSRF - PullRequest
       60

Форма только с токеном CSRF

0 голосов
/ 07 февраля 2019

У меня есть форма, которая требует только токен CRSF.Другие параметры предоставляются из самого URL-адреса или являются значением по умолчанию.

/**
 * @Route("/projets/projet-{projetId}/accessoires/accessoire-{accessoireId}/new/", name="projetaccessoire_new")
 * @ParamConverter("projet", options={"mapping"={"projetId"="id"}})
 * @ParamConverter("accessoire", options={"mapping"={"accessoireId"="id"}})
 * @Method({"POST")
 *
 * @param Request $request
 * @param Projet $projet
 * @param Accessoire $accessoire
 * @return \Symfony\Component\HttpFoundation\RedirectResponse|\Symfony\Component\HttpFoundation\Response
 */
public function newAction(Request $request, Projet $projet, Accessoire $accessoire) {
    $projetAccessoire=new ProjetAccessoire();
    $form=$this->createForm(ProjetAccessoireType::class, $projetAccessoire, array(
        'action'=>$this->generateUrl('projetaccessoire_new', array('projetId'=>$projet->getId(), 'accessoireId'=>$accessoire->getId())),
        'method'=>'POST',
    ));
    $form->handleRequest($request);

    if($form->isSubmitted() && $form->isValid()) {
        $projetAccessoire->setProjets($projet)
                         ->setAccessoires($accessoire)
                         ->setPosX(0)
                         ->setPosY(0)
                         ->setRotZ(0);

        $em=$this->getDoctrine()->getManager();
        $em->persist($projetAccessoire);
        $em->flush();

        return $this->json(array(
            'message_info'=>array(
                array(
                    'message'=>'Projet enregistré',
                    'type'=>'success',
                ),
            ),
        ));
    }

    return $this->render($this->path.'projetaccessoire_new.html.twig', array(
        'projet'=>$projet,
        'accessoire'=>$accessoire,
        'projetAccessoire'=>$projetAccessoire,
        'form'=>$form->createView(),
    ));
}

Дело в том, что я должен вставить в ProjetAccessoireType, чтобы получить только токен CRSF.
Может ли кто-нибудь предоставить мнепример кода?

Ответы [ 2 ]

0 голосов
/ 07 февраля 2019

Если вам нужен только токен csrf, не проще ли создать форму без класса данных?

https://symfony.com/doc/current/form/without_class.html

0 голосов
/ 07 февраля 2019

Для того, что вы пытаетесь сделать, вам не нужен выделенный тип формы.Просто используйте базовый тип:

use Symfony\Component\Form\Extension\Core\Type\FormType;

// ...
$form = $this->createForm(FormType::class);

// or
$form = $this->createFormBuilder()->getForm();

Это создаст пустую форму только со скрытым вводом crsf-токена.

...