web-dev-qa-db-fra.com

Recaptcha missing-input-response

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

4
Forlis

Veuillez noter: g-recaptcha-respone! = g-recaptcha-response

 enter image description here

 enter image description here

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
7
Akshay Hegde

Dans mon cas, je devais ajouter deux paramètres supplémentaires ('', '&') dans cet appel:

http_build_query(array(
    'secret' => $secret,
    'response' => $response,
    'remoteip' => $remoteip
), '', '&');
1
Marek Skiba

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));
}
0
alen