«отсутствует входной ответ» ошибка recaptcha v3 - PullRequest
0 голосов
/ 26 марта 2019

Я создаю форму для отправки электронных писем с recaptcha. Все работало отлично, но я заметил, что recaptcha v3 длился всего 3 минуты и нужно было сбросить. Оттуда он начал выдавать ошибку «missing-input-response».

index.php

<script>
  grecaptcha.ready(function() {
      grecaptcha.execute('key', {action: 'homepage'}).then(function(token) {
         document.getElementById('g-recaptcha-response').value=token;
      }); 
  });
  </script>

  <script>
    var callback = function() {
      grecaptcha.render('id-of-render-element', {
         'sitekey': 'key',
         'expired-callback': expCallback
       });
   };
   var expCallback = function() {
      alert("Your recatpcha has expired, please verify again ...");
      setInterval(function(){ grecaptcha.reset(); }, 5 * 60 * 1000 ); 
   };
  </script>

 <div id="id-of-render-element"></div>
<script src="https://www.google.com/recaptcha/api.js?onload=callback&render=explicit" async defer></script>

класс капчи

<?php

    class Captcha{

    public function getCaptcha($SecretKey){

        $Resposta = file_get_contents("https://www.google.com/recaptcha/api/siteverify?secret=key&response={$SecretKey}");
        $Retorno = json_decode($Resposta);
        return $Retorno;
    }

     public function returnCaptcha(){
         echo "entrou calss_captcha";
  $EnviaMail = False;
  $ObjCaptcha = new Captcha();
  $Retorno=$ObjCaptcha->getCaptcha($_POST['g-recaptcha-response']);
  var_dump($Retorno);
  if($Retorno->success == true && $Retorno->score > 0.5){
      $EnviaMail = True;
  }else{
      $EnviaMail = False;
  }
  return $EnviaMail;
    }
    }

?>

1 Ответ

0 голосов
/ 27 марта 2019

Согласно пользовательскому комментарию, работающему для Версии 2. Вам необходимо указать дополнительные параметры для вызова функции file_get_contents и, если на вашем сайте есть SSL, тогда задайте параметры контекста.

class Captcha{        
    public function getCaptcha($SecretKey){
        if($SecretKey){
            // Input data
            $secret = 'SECRET_KEY';
            $response = $SecretKey;
            $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 );
            $Resposta = file_get_contents( $url, false, $context );
            $Retorno = json_decode($Resposta);
            return $Retorno;
        }
    }
    public function returnCaptcha(){
        echo "entrou calss_captcha";
        $EnviaMail = False;
        $ObjCaptcha = new Captcha();
        $Retorno=$ObjCaptcha->getCaptcha($_POST['g-recaptcha-response']);
        var_dump($Retorno);
        if($Retorno->success == true && $Retorno->score > 0.5){
            $EnviaMail = True;
        }else{
            $EnviaMail = False;
        }
        return $EnviaMail;
    }
}
...