У меня есть сайт с простой формой контакта. Валидация несколько минимальна, поскольку она не входит в базу данных; просто по электронной почте. Форма работает как таковая:ReCaptcha не работает должным образом на iPhone
Существует 5 полей - 4 из которых необходимы. Представление отключено до тех пор, пока не будут введены 4 поля, и вы сможете отправить их. Затем все снова проверяется на сервере, в том числе recaptcha (который не проверяется мной на стороне клиента). Весь процесс выполняется с помощью ajax, и есть несколько тестов, которые должны проходить на стороне сервера или возвращаются 4 ** заголовка, и вызывается обработчик обратного вызова fail.
Все работает как gangbusters на Chrome на рабочем столе (я не пробовал другие браузеры, но я не могу представить, почему они будут разными), но на iPhone reCaptcha всегда проверяет, даже если я не установите флажок для теста.
Другими словами: я все равно должен правильно заполнить четыре значения для отправки, но если я не поставлю флажок для reCaptcha, запрос все равно будет выполнен.
Я могу опубликовать код, если кто-то подумает, что это будет полезно, но, похоже, проблема связана с устройством, а не с кодом. Кто-нибудь может понять это?
Примечание: на стороне сервера является PHP/Apache, если это полезно.
Обновление: 5/28/2015:
Я до сих пор отладки, но это, кажется, как Mobile Safari игнорирует мои заголовки ответа на моем iPhone. Когда я выход ответ на страницу, что я получаю на рабочем столе для (data,status,xhr)
является:
data
: мой ответ, который в этот момент как раз говорит об ошибке или успех ->error
status
:error
xhr
:{'error',400,'error'}
на мобильном сафари:
data
:error
status
:success
xhr
:{'error',200,'success'}
Итак - похоже, что это просто игнорирует мои заголовки ответов. Я попытался явно установить {"headers":{"cache-control":"no-cache"}}
, но безрезультатно.
обновление: 6/3/2015
Per Request, вот код. Это почти наверняка больше, чем вам нужно. Он также стал более тупым из-за изменений, которые я сделал, чтобы попытаться исправить это. Также обратите внимание, что, хотя может показаться, что существуют переменные, которые не были определены, они (должны) были определены в других файлах.
The client side
$('#submit').on('click', function(e) {
$(this).parents('form').find('input').each(function() {
$(this).trigger('blur');
})
var $btn = $(this);
$btn = $btn.button('loading');
var dfr = $.Deferred();
if ($(this).attr('disabled') || $(this).hasClass('disabled')) {
e.preventDefault();
e.stopImmediatePropagation();
dfr.reject();
return false;
} else {
var input = $('form').serializeArray();
var obj = {},
j;
$.each(input, function(i, a) {
if (a.name === 'person-name') {
obj.name = a.value;
} else if (a.name === 'company-name') {
obj.company_name = a.value;
} else {
j = a.name.replace(/(g-)(.*)(-response)/g, '$2');
obj[j] = a.value;
}
});
obj.action = 'recaptcha-js';
obj.remoteIp = rc.remoteiP;
rc.data = obj;
var request = $.ajax({
url: rc.ajaxurl,
type: 'post',
data: obj,
headers: {
'cache-control': 'no-cache'
}
});
var success = function(data) {
$btn.data('loadingText', 'Success');
$btn.button('reset');
$('#submit').addClass('btn-success').removeClass('btn-default');
$btn.button('loading');
dfr.resolve(data);
};
var fail = function(data) {
var reason = JSON.parse(data.responseText).reason;
$btn.delay(1000).button('reset');
switch (reason) {
case 'Recaptcha Failed':
case 'Recaptcha Not Checked':
case 'One Or more validator fields not valid or not filled out':
case 'One Or more validator fields is invalid':
// reset recaptcha
if ($('#submit').data('tries')) {
$('#submit').remove();
$('.g-recaptcha').parent().addBack().remove();
myPopover('Your request is invalid. Please reload the page to try again.');
} else {
$('#submit').data('tries', 1);
grecaptcha.reset();
myPopover('One or more of your entries are invalid. Please make corrections and try again.');
}
break;
default:
// reset page
$('#submit').remove();
$('.g-recaptcha').remove();
myPopover('There was a problem with your request. Please reload the page and try again.');
break;
}
dfr.reject(data);
};
request.done(success);
request.fail(fail);
}
The Server:
function _send_email(){
$recaptcha=false;
/* * */
if(isset($_POST['recaptcha'])):
$gRecaptchaResponse=$_POST['recaptcha'];
$remoteIp=isset($_POST['remoteIp']) ? $_POST['remoteIp'] : false;
/* ** */
if(!$remoteIp):
$response=array('status_code'=>'409','reason'=>'remoteIP not set');
echo json_encode($response);
http_response_code(409);
exit();
endif;
/* ** */
/* ** */
if($gRecaptchaResponse==''):
$response=array('status_code'=>'400','reason'=>'Recaptcha Failed');
echo json_encode($response);
http_response_code(400);
exit();
endif;
/* ** */
if($recaptcha=recaptcha_test($gRecaptchaResponse,$remoteIp)):
$recaptcha=true;
/* ** */
else:
$response=array('status_code'=>'400','reason'=>'Recaptcha Failed');
echo json_encode($response);
http_response_code(400);
exit();
endif;
/* ** */
/* * */
else:
$response=array('status_code'=>'400','reason'=>'Recaptcha Not Checked');
echo json_encode($response);
http_response_code(400);
exit();
endif;
/* * */
/* * */
if($recaptcha==1):
$name=isset($_POST['name']) ? $_POST['name'] : false;
$company_name=isset($_POST['company_name']) ? $_POST['company_name'] : false;
$phone=isset($_POST['phone']) ? $_POST['phone'] : false;
$email=isset($_POST['email']) ? $_POST['email'] : false;
/* ** */
if(isset($_POST['questions'])):
$questions=$_POST['questions']=='' ? 1 : $_POST['questions'];
/* *** */
if(!$questions=filter_var($questions,FILTER_SANITIZE_SPECIAL_CHARS)):
$response=array('status_code'=>'400','reason'=>'$questions could not be sanitized');
echo json_encode($response);
http_response_code(400);
exit();
endif;
/* *** */
/* ** */
else:
$questions=true;
endif;
/* ** */
/* ** */
if(count(array_filter(array($name,$company_name,$phone,$email),"filter_false")) !=4):
$response=array('status_code'=>'400','reason'=>'One Or more validator fields not valid or not filled out');
echo json_encode($response);
http_response_code(400);
exit();
endif;
/* ** */
$company_name=filter_var($company_name,FILTER_SANITIZE_SPECIAL_CHARS);
$name=filter_var($name,FILTER_SANITIZE_SPECIAL_CHARS);
$phone=preg_replace('/[^0-9+-]/', '', $phone);
$email=filter_var($email,FILTER_VALIDATE_EMAIL);
/* ** */
if($company_name && $recaptcha && $name && $phone && $email && $questions):
$phone_str='Phone: ' . $phone;
$company_str='Company: ' . $company_name;
$email_str='Email String: ' . $email;
$name_str='Name: '.$name;
$questions=$questions==1 ? '' : $questions;
$body="$name_str\r\n\r\n$company_str\r\n\r\n$email_str\r\n\r\n$phone_str\r\n\r\n____________________\r\n\r\n$questions";
$mymail='[email protected]';
$headers = array();
$headers[] = "MIME-Version: 1.0";
$headers[] = "Content-type: text/plain; charset=\"utf-8\"";
$headers[] = "From: $email";
$headers[] = "X-Mailer: PHP/" . phpversion();
/* *** */
if(mail('$mymail', 'Information Request from: ' . $name,$body,implode("\r\n",$headers))):
$response=array('status_code'=>'200','reason'=>'Sent !');
echo json_encode($response);
http_response_code(200);
exit();
/* *** */
else:
$response=array('status_code'=>'400','reason'=>'One Or more validator fields is invalid');
echo json_encode($response);
http_response_code(400);
exit();
endif;
/* *** */
endif;
/* ** */
endif;
/* * */
$response=array('status_code'=>'412','reason'=>'There was an unknown error');
echo json_encode($response);
http_response_code(412);
exit();
}
function recaptcha_test($gRecaptchaResponse,$remoteIp){
$secret=$itsasecret; //removed for security;
require TEMPLATE_DIR . '/includes/lib/recaptcha/src/autoload.php';
$recaptcha = new \ReCaptcha\ReCaptcha($secret);
$resp = $recaptcha->verify($gRecaptchaResponse, $remoteIp);
if ($resp->isSuccess()) {
return true;
// verified!
} else {
$errors = $resp->getErrorCodes();
return false;
}
}
Нужно использовать Javascript для отправки запроса AJAX, чтобы помочь вам отладить. Вы POSTING (скажите «да»), а не GETting?Если вы используете GETting и не можете публиковать сообщения, убедитесь, что вы добавили кеш-запрос в запрос (не полагайтесь только на заголовки, так как есть много вещей, в которых заголовки могут игнорироваться). Но опубликуйте JS, и мы можем помочь оттуда. – Robbie
@ user1167442 да, пожалуйста, предоставьте некоторый код :) было бы полезно здесь. – sitilge
Да - метод POST. Код добавлен. Благодарю. – user1167442