Валидация ревизии Botdetect в Symfony 4 без использования сущности - PullRequest
0 голосов
/ 20 февраля 2019

Есть ли какой-либо способ проверить BotDetect recaptcha в конструкторе форм Symfony?

У меня есть приведенная ниже форма, которая позволяет пользователю вводить свою электронную почту .:

     $form = $this->createFormBuilder()
        ->add('email', EmailType::class,[
            'label' => false,
            'attr' => [
                'style' => 'text-align:center;',
                'value' => $email,
            ]
        ])
        ->add('captchaCode', CaptchaType::class, array(
            'captchaConfig' => 'ExampleCaptcha'
        ))
        ->add('Do some shiz wif my email bruh.', SubmitType::class)
        ->getForm();

    $form->handleRequest($request);

    if ($form->isSubmitted() && $form->isValid()) {
        return $this->redirect('/unblock/'.$email);
    }

Проблемас этим, их документация определяет ограничение проверки в Entity.В моем приложении нет объектов (пока), но я хотел бы знать, нашел ли кто-нибудь способ проверки капчи с контроллера?

Я в порядке, добавив его в свои объекты при созданииих, но мне интересно, как это будет сделано в приложении, которое не имеет каких-либо сущностей или подключения к базе данных.

1 Ответ

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

В итоге я использовал пакет beelabs google recaptcha из packagist (если кому-то интересно) по ссылке: https://packagist.org/packages/beelab/recaptcha2-bundle

Их документация расскажет вам почти все, что вам нужно знать об установке и настройке.

Единственным недостатком является то, что он по-прежнему позволяет отправлять форму, даже если вы не установили флажок Я не робот, поэтому вам нужно будет проверить, была ли нажата кнопка на стороне PHP.

Вы можете использовать это, чтобы получить ответ, который обычно является либо хешем, либо пустым полем.

$recaptcha = $request->get('g-recaptcha-response', '');
...