Проверьте вызов Ajax в Symfony с CSRF и Captha - PullRequest
0 голосов
/ 02 сентября 2018

Я отрисовываю форму из следующего метода контроллера:

  public function indexAction(Request $request)
    {

        $session=$this->get('session');
        $builder = $this->get('app.captcha');
        $builder->build();
        $session->set('registration_step2',$builder->getPhrase());

        return $this->render('pages/registration.html.twig',[
          'image'=>$this->createCaptcha('registration_step2')
        ])
   }

Форма, которую я отображаю, pages/registration.html.twig:

<form id="contactForm" class="col-12" data-scroll-to="displayRegistationPaperApplicationWrapper" action="{{ path('registration_email_contact') }}" method="post">
       <input type="hidden" name="csrf" value="{{ csrf_token('insert-email') }}"/>

         <div class="col-12 mb-3">
           <div class="col-12">
             <div class="input-group">
                <div class="input-group-prepend">
                  <button class="btn btn-secondary" data-autofill-to="autofill_email" data-autofill-from="registrationEmail" id="emailAutofill">{{ 'register.step2.email.autofill'|trans }}</button>
                </div>
                <input id="autofill_email" type="email"  name="autofill_email" class="form-control" placeholder="{{ 'register.step2.email'|trans }}" required/>
              </div>
           </div>
         </div>
        <div class="col-12">
           <div class="col-2 float-left border">
             <img id="capthaImage" class="img-fluid" data-captha-renew="registration_step2" src="{{ image }}">
           </div>
           <div class="col-10 float-right">
             <div class="input-group">
                <div class="input-group-prepend">
                  <button class="btn btn-secondary" id="reset-captcha">{{ 'register.captha.new-image'|trans }}</button>
                </div>
                <input type="text" name="captcha" class="form-control" placeholder="{{ 'register.captcha'|trans }}" required/>
              </div>
           </div>
         </div>
         <div class="col-12 mt-5 mb-2">
           <div class="col-12 col-sm-12 col-md-5 col-lg-5 ml-auto">
            <div class="btn-group" role="group" aria-label="Basic example">
              <button id="rejectEmail" data-scroll-to="displayRegistationPaperApplicationWrapper" type="button" class="btn btn-link text-danger">{{ 'register.step2.no'|trans }}</button>
              <button type="submit" class="btn btn-success">{{ 'register.step2.yes'|trans }}</button>
            </div>
          </div>
         </div>
    </form>

Форма будет отправлена ​​через Ajax (я не размещаю код javascript, чтобы вопрос был как можно меньше), используя отдельный метод контроллера. Например:

public function submitFormAction(Request $request)
{
  // Implement sumbit code here
}

То, что я хочу сначала протестировать с помощью функционального теста phpunit, - это нормальное поведение отправки ajax, но как я получу: * Текущий токен csrf * Строка Captha

БЕЗ необходимо полностью отобразить страницу, на которой размещены токен csrf и капча (поскольку она является частью множественной формы).

Для капчи я использую реализацию gregwar и определяю ее как сервис через:

app.captcha:
  class: 'Gregwar\Captcha\CaptchaBuilder'
  public: true

(Я не пользуюсь Bundle, потому что считаю, что это неудобно в моем случае, когда я использую Ajax. Я планирую сделать свой собственный Сервис в немедленном рефакторинге.)

...