Я хочу внедрить 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">×</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 не был подтвержден. Я хотел бы знать, что я могу сделать, чтобы иметь возможность проверить мои капчи.
Заранее спасибо.