Как правильно добавить Google ReCaptcha

  • Автор темы syltan02091989
  • 26
  • Обновлено
  • 17, May 2024
  • #1
У меня есть контактная форма PHP, которая выполняет проверку через AJAX/JSON на стороне сервера и отправляет ошибки в Javascript, чтобы распечатать ошибки и соответствующим образом изменить HTML/CSS. Как правильно реализовать Google ReCaptcha с проверкой AJAX? Вот моя попытка кода.
Фрагмент ReCaptcha:
  // Start

$(document).ready(function() {

// process the form

$('form').submit(function(event) {

$('.form-group').removeClass('has-error'); // remove the error class

$('.help-block').remove(); // remove the error text

// get the form data

// there are many ways to get this data using jQuery (you can use the class or id also)

var formData = {

'firstName' : $('input[name=firstName]').val(),

'lastName' : $('input[name=lastName]').val(),

'companyName' : $('input[name=companyName]').val(),

'companyAddress' : $('input[name=companyAddress]').val(),

'city' : $('input[name=city]').val(),

'state' : $('input[name=state]').val(),

'emailAddress' : $('input[name=emailAddress]').val(),

'comment' : $('input[name=comment]').val()

};

// process the form

$.ajax({

type : 'POST', // define the type of HTTP verb we want to use (POST for our form)

url : 'formMaster.php', // the url where we want to POST

data : formData, // our data object

dataType : 'json', // what type of data do we expect back from the server

encode : true

})

// using the done promise callback

.done(function(data) {

// log data to the console so we can see

console.log(data);

// here we will handle errors and validation messages

if ( ! data.success) {

// handle errors for name ---------------

if (data.errors.firstName) {

$('#firstName-group').addClass('has-error'); // add the error class to show red input

$('#firstName-group').append('<div class="help-block">' + data.errors.firstName + '</div>'); // add the actual error message under our input

}

// handle errors for name ---------------

if (data.errors.lastName) {

$('#lastName-group').addClass('has-error'); // add the error class to show red input

$('#lastName-group').append('<div class="help-block">' + data.errors.lastName + '</div>'); // add the actual error message under our input

}

// handle errors for name ---------------

if (data.errors.companyName) {

$('#companyName-group').addClass('has-error'); // add the error class to show red input

$('#companyName-group').append('<div class="help-block">' + data.errors.companyName + '</div>'); // add the actual error message under our input

}

// handle errors for Company Address ---------------

if (data.errors.companyAddress) {

$('#companyAddress-group').addClass('has-error'); // add the error class to show red input

$('#companyAddress-group').append('<div class="help-block">' + data.errors.companyAddress + '</div>'); // add the actual error message under our input

}

// handle errors for Company Address ---------------

if (data.errors.city) {

$('#city-group').addClass('has-error'); // add the error class to show red input

$('#city-group').append('<div class="help-block">' + data.errors.city + '</div>'); // add the actual error message under our input

}

// handle errors for Company Address ---------------

if (data.errors.state) {

$('#state-group').addClass('has-error'); // add the error class to show red input

$('#state-group').append('<div class="help-block">' + data.errors.state + '</div>'); // add the actual error message under our input

}

// handle errors for Email Address ---------------

if (data.errors.emailAddress) {

$('#emailAddress-group').addClass('has-error'); // add the error class to show red input

$('#emailAddress-group').append('<div class="help-block">' + data.errors.emailAddress + '</div>'); // add the actual error message under our input

}

// handle errors for superhero alias ---------------

if (data.errors.comment) {

$('#comment-group').addClass('has-error'); // add the error class to show red input

$('#comment-group').append('<div class="help-block">' + data.errors.comment + '</div>'); // add the actual error message under our input

}

} else {

// ALL GOOD! just show the success message!

$('form').append('<div class="alert alert-success">' + data.message + '</div>');

// usually after form submission, you'll want to redirect

// window.location = '/thank-you'; // redirect a user to another page

}

})

// using the fail promise callback

.fail(function(data) {

// show any errors

// best to remove for production

console.log(data);

});

// stop the form from submitting the normal way and refreshing the page

event.preventDefault();

});

});
PHP: PHP:

  <?php $errors = array(); // array to hold validation errors $data = array(); // array to pass back data // validate the variables ====================================================== // if any of these variables don't exist, add an error to our $errors array if (empty($_POST['firstName'])) $errors['firstName'] = 'First Name is required.'; if (empty($_POST['lastName'])) $errors['lastName'] = 'Last Name is required.'; if (empty($_POST['companyName'])) $errors['companyName'] = 'Company Name is required.'; if (empty($_POST['companyAddress'])) $errors['companyAddress'] = 'Company Address is required.'; if (empty($_POST['city'])) $errors['city'] = 'City is required.'; if (empty($_POST['state'])) $errors['state'] = 'State is required.'; if (empty($_POST['emailAddress'])) $errors['emailAddress'] = 'Email Address is required.'; if (empty($_POST['comment'])) $errors['comment'] = 'Comment is required.'; //reCAPTCHA validation if (isset($_POST['g-recaptcha-response'])) { require('component/recaptcha/src/autoload.php'); $recaptcha = new \ReCaptcha\ReCaptcha(SECRET_KEY, new \ReCaptcha\RequestMethod\SocketPost()); $resp = $recaptcha->verify($_POST['g-recaptcha-response'], $_SERVER['REMOTE_ADDR']); if (!$resp->isSuccess()) { $errors = json_encode(array('type'=>'error', 'text' => 'Captcha is Required!')); die($output); } } // return a response =========================================================== // if there are any errors in our errors array, return a success boolean of false if ( ! empty($errors)) { // if there are items in our errors array, return those errors $data['success'] = false; $data['errors'] = $errors; } else { // if there are no errors process our form, then return a message // DO ALL YOUR FORM PROCESSING HERE // THIS CAN BE WHATEVER YOU WANT TO DO (LOGIN, SAVE, UPDATE, WHATEVER) // show a message of success and provide a true success variable $data['success'] = true; $data['message'] = 'Success!'; } // return all our data to an AJAX call echo json_encode($data);
PHP: Javascript:
  //reCAPTCHA validation if (isset($_POST['g-recaptcha-response'])) { require('component/recaptcha/src/autoload.php'); $recaptcha = new \ReCaptcha\ReCaptcha(SECRET_KEY, new \ReCaptcha\RequestMethod\SocketPost()); $resp = $recaptcha->verify($_POST['g-recaptcha-response'], $_SERVER['REMOTE_ADDR']); if (!$resp->isSuccess()) { $errors = json_encode(array('type'=>'error', 'text' => 'Captcha is Required!')); die($output); } }
Код (JavaScript): Прямо сейчас я просто не понимаю, как заставить это работать правильно.

Получается ли ответ проверки с помощью Javascript или PHP, или Javascript передает его PHP? Если возникла ошибка, как передать ее в Javascript, чтобы распечатать ошибку? Я прав?

syltan02091989


Рег
05 Dec, 2015

Тем
1

Постов
3

Баллов
13
Тем
49554
Комментарии
57426
Опыт
552966

Интересно