Bootstrap капча не проверяет ответ - PullRequest
0 голосов
/ 15 октября 2019

Я хочу внедрить Google ReCaptcha для моего проекта, и я следую учебному пособию в https://bootstrapious.com/p/bootstrap-recaptcha,, используя стандартные ключи для тестирования на локальном компьютере, полученные с этого сайта .

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

    <form id="form_register" method="post" role="form" name="form_register"> 
      <!-- Some inputs -->
       <div class="form-group">
             <div class="g-recaptcha" data-sitekey="6LeIxAcTAAAAAJcZVRqyHh71UMIEGNQ_MXjiZKhI" data-callback="verifyRecaptchaCallback" data-expired-callback="expiredRecaptchaCallback"></div>
             <input class="form-control d-none" data-recaptcha="true" required data-error="Please complete the Captcha">
             <div class="help-block with-errors"></div>
       </div>
       <button type="submit" class="mixpanel_link_registro btn btn-lg btn-primary btn-extra-mobile w-100"> Save </button>
    </form>

И это код JS:

        <script src='https://www.google.com/recaptcha/api.js'></script>
        <script src="validator.js"></script>


        <script>
          $(function () {

            window.verifyRecaptchaCallback = function (response) {
                $('input[data-recaptcha]').val(response).trigger('change')
            }

            window.expiredRecaptchaCallback = function () {
                $('input[data-recaptcha]').val("").trigger('change')
            }

            $('#form_register').validator();

            $('#form_register').on('submit', function (e) {
                if (!e.isDefaultPrevented()) {
                  var url = "recaptcha.php";
                  $.ajax({
                      type: "POST",
                      url: url,
                      data: $(this).serialize(),
                      success: function (data) {
                        var messageAlert = 'alert-' + data.type;
                        var messageText = data.message;

                        var alertBox = '<div class="alert ' + messageAlert + ' alert-dismissable"><button type="button" class="close" data-dismiss="alert" aria-hidden="true">&times;</button>' + messageText + '</div>';
                        if (messageAlert && messageText) {
                            $('#form_register').find('.messages').html(alertBox);
                            $('#form_register')[0].reset();
                            grecaptcha.reset();
                        }
                      },
                      error: function (xhr, ajaxOptions, thrownError) {
                        alert(xhr.status);
                        alert(thrownError);
                      }
                  });
                  return false;
                }
            })
          });
        </script>

Однако, когда он идет в мой файл recaptcha.php через ajax,это не подтверждает мой ответ. Я использовал следующий код PHP:

require('recaptcha-master/src/autoload.php');

// ReCaptch Secret
$recaptchaSecret = '6LeIxAcTAAAAAGG-vFI1TnRWxMZNFuojJ4WifJWe';

error_reporting(E_ALL & ~E_NOTICE);

try {
    if (!empty($_POST)) {
       // validate the ReCaptcha, if something is wrong, we throw an Exception,
       // i.e. code stops executing and goes to catch() block

       if (!isset($_POST['g-recaptcha-response'])) {
           throw new \Exception('ReCaptcha is not set.');
       }

       $recaptcha = new \ReCaptcha\ReCaptcha($recaptchaSecret, new \ReCaptcha\RequestMethod\CurlPost());

       // we validate the ReCaptcha field together with the user's IP address
       $server = $_SERVER['REMOTE_ADDR'] . ":" . $_SERVER['SERVER_PORT'];
       $response = $recaptcha->verify($_POST['g-recaptcha-response'], $server);

       if (!$response->isSuccess()) {
           throw new \Exception('ReCaptcha was not validated.');
       }

    }
 } catch (\Exception $e) {
   $_SESSION["error"] = $e;
 }

Печать переменной recaptcha дает мне следующий вывод:

__PHP_Incomplete_Class Object ( [__PHP_Incomplete_Class_Name] => ReCaptcha\ReCaptcha [secret:ReCaptcha\ReCaptcha:private] => 6LeIxAcTAAAAAGG-vFI1TnRWxMZNFuojJ4WifJWe [requestMethod:ReCaptcha\ReCaptcha:private] => __PHP_Incomplete_Class Object ( [__PHP_Incomplete_Class_Name] => ReCaptcha\RequestMethod\CurlPost [curl:ReCaptcha\RequestMethod\CurlPost:private] => __PHP_Incomplete_Class Object ( [__PHP_Incomplete_Class_Name] => ReCaptcha\RequestMethod\Curl ) ) )

И я получаю исключениеэто говорит: Recaptcha не был подтвержден. Я хотел бы знать, что я могу сделать, чтобы иметь возможность проверить мои капчи.

Заранее спасибо.

...