Salut les gars, j'ai un problème avec Google reCaptcha.
Voici mon code php:
$secret = 'SECRET_KEY';
$response = $_POST['g-recaptcha-respone'];
$remoteip = $_SERVER['REMOTE_ADDR'];
$url = "https://www.google.com/recaptcha/api/siteverify?secret=$secret&response=$response&remoteip=$remoteip";
$result_json = file_get_contents($url);
$resulting = json_decode($result_json, true);
print_r($resulting);
if($resulting['success']) {
//Success
}
l'entrée de print_r est: Array ([succès] => [codes d'erreur] => Array ([0] => missing-input-response))
Comment résoudre ce problème?
Merci pour les réponses
Veuillez noter: g-recaptcha-respone
! = g-recaptcha-response
API Google reCatcha, vous devrez peut-être spécifier des paramètres supplémentaires pour l'appel de la fonction file_get_contents
, en définissant les options de contexte spécifiquement pour SSL (si le site utilise SSL).
// If submitted check response
if ($_POST["g-recaptcha-response"]) {
// Input data
$secret = 'SECRET_KEY';
$response = $_POST['g-recaptcha-response'];
$remoteip = $_SERVER['REMOTE_ADDR'];
$url = "https://www.google.com/recaptcha/api/siteverify";
$post_data = http_build_query(
array(
'secret' => $secret,
'response' => $response,
'remoteip' => $remoteip
)
);
$options=array(
// If site has SSL then
'ssl'=>array(
// In my case its /etc/ssl/certs/cacert.pem
'cafile' => '/path/to/cacert.pem',
'verify_peer' => true,
'verify_peer_name' => true,
),
'http' =>
array(
'method' => 'POST',
'header' => 'Content-type: application/x-www-form-urlencoded',
'content' => $post_data
)
);
$context = stream_context_create( $options );
$result_json = file_get_contents( $url, false, $context );
$resulting = json_decode($result_json, true);
if($resulting['success']) {
//Success
} else {
// action for no response
}
Au moins sur ubuntu - Si le site utilise SSL
cd /usr/local/share/ca-certificates
Sudo curl http://curl.haxx.se/ca/cacert.pem -o cacert.crt
Sudo update-ca-certificates
Sudo update-ca-certificates –fresh
et votre cafile et chemin seront
capath=/etc/ssl/certs/
cafile=/etc/ssl/certs/cacert.pem
Dans mon cas, je devais ajouter deux paramètres supplémentaires ('', '&'
) dans cet appel:
http_build_query(array(
'secret' => $secret,
'response' => $response,
'remoteip' => $remoteip
), '', '&');
je ne suis pas en mesure de commenter, alors je vais répondre ici. J'ai copié mon code qui fonctionne parfaitement. et d'ailleurs, $ _POST ['g-recaptcha-response'], êtes-vous sûr que le nom de vos entrées est 'g-recaptcha-response'?
$secret = 'SECRET-KEY';
$response = $_POST['g-recaptcha-response'];
$ip = $_SERVER['REMOTE_ADDR'];
$dav = file_get_contents("https://www.google.com/recaptcha/api/siteverify?secret=".$secret."&response=".$response."&remoteip=".$ip);
$res = json_decode($dav,true);
if($res['success']) {
die(json_encode(0));
} else {
die(json_encode(1));
}