Probleme recaptchaV2 et file_get_contents

failed to open stream: Connection timed out

Le problème exposé dans ce sujet a été résolu.

Bonjour à tous ! Ca faisait longtemps !

J’ai un soucis sur un formulaire de contact. J’ai installé le recaptcha et fait plusieurs tests et ca fonctionnait très bien.

Et là, hop plus rien à faire ! Impossible d’envoyer mon formulaire, j’ai un message d’erreur :

"Warning: file_get_contents(https://www.google.com/recaptcha/api/siteverify?secret=XXXXXXXXXXXXXXXXXXresponse=XXXXXXXXXXXXXXXXXXX&remoteip=XXXXXXXXXXX): failed to open stream: Connection timed out in /var"

Ce que je ne comprends pas, c’est qu’en prenant le lien google dans le warning, voilà ce que j’ai:

success true

challenge_ts "2017-10-30T18:13:17Z"

hostname "clenake"

ensuite seulement ça passe à false si j’actualise.

Dans mon $_POST j’ai bien la réponse de google.

Et quand j’envoie le form sans le captcha, je n’est pas la reponse google, normal, mais j’ai quand même le warning.

Est-ce que quelqu’un pourrait m’aider ?

Merci à vous tous

Salut !

Plus tôt dans la journée, on a eu un souci très similaire. J’ai l’impression que c’est non seulement localisé, mais en plus temporaire, dans la mesure ou ça fonctionnait chez moi alors que deux collègues ne pouvaient plus rien faire, et quand ils ont pu réutiliser, moi je n’ai plus pu. Je n’ai pas trop creusé la chose, ça avait fonctionné sans souci depuis plus d’une année, on n’avait strictement rien touché à ce niveau…

J’ai vaguement l’impression, d’après ce que tu dis, que Google a déployé quelque chose de nouveau — à noter qu’officiellement depuis demain, les sites utilisant encore la version 1 de reCaptcha auront droit à un avertissement directement dans ce que génère Google, c’est peut-être le déploiement de cette modification pour la vieille API qui a ralenti et potentiellement bloqué le trafic.

+0 -0

Salut ! Merci de ta réponse :)

J’espère que c’est ca parce que je cheche le problème depuis hier soir et rien à faire !

J’ai essayé aussi avec file() et fopen et le résultat est le même.

J’avais ajouter localhost pour les clés de google et je l’ai supprimer en me disant que ca venait peut être de là, mais ca n’a rien changé non plus.

Bref, j’espère que ca vient de google !!

En fait je suis dégoutée !! Pour une fois que j’avais réussi à intégrer un truc presque du 1er coup :)

Je vais attendre un jour ou deux de voir si ca revient, sinon ce sera avec plaisir parce que j’ai clairement pas le niveau de faire un captcha toute seule.

Merci en tous cas :)

Non, il utilise aussi file_get_contents().

Le problème pourrait être que free n’a pas activé le wrapper HTTPS…

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
<?php
/**
 * This is a PHP library that handles calling reCAPTCHA.
 *    - Documentation and latest version
 *          https://developers.google.com/recaptcha/docs/php
 *    - Get a reCAPTCHA API Key
 *          https://www.google.com/recaptcha/admin/create
 *    - Discussion group
 *          http://groups.google.com/group/recaptcha
 *
 * @copyright Copyright (c) 2014, Google Inc.
 * @link      http://www.google.com/recaptcha
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */

/**
 * A ReCaptchaResponse is returned from checkAnswer().
 */
class ReCaptchaResponse
{
    public $success;
    public $errorCodes;
}

class ReCaptcha
{
    private static $_signupUrl = "https://www.google.com/recaptcha/admin";
    private static $_siteVerifyUrl =
        "https://www.google.com/recaptcha/api/siteverify?";
    private $_secret;
    private static $_version = "php_1.0";

    /**
     * Constructor.
     *
     * @param string $secret shared secret between site and ReCAPTCHA server.
     */
    function ReCaptcha($secret)
    {
        if ($secret == null || $secret == "") {
            die("To use reCAPTCHA you must get an API key from <a href='"
                . self::$_signupUrl . "'>" . self::$_signupUrl . "</a>");
        }
        $this->_secret = $secret;
    }

    /**
     * Encodes the given data into a query string format.
     *
     * @param array $data array of string elements to be encoded.
     *
     * @return string - encoded request.
     */
    private function _encodeQS($data)
    {
        $req = "";
        foreach ($data as $key => $value) {
            $req .= $key . '=' . urlencode(stripslashes($value)) . '&';
        }

        // Cut the last '&'
        $req = substr($req, 0, strlen($req)-1);
        return $req;
    }

    /**
     * Submits an HTTP GET to a reCAPTCHA server.
     *
     * @param string $path url path to recaptcha server.
     * @param array  $data array of parameters to be sent.
     *
     * @return array response
     */
    private function _submitHTTPGet($path, $data)
    {
        $req = $this->_encodeQS($data);
        $response = file_get_contents($path . $req);
        return $response;
    }

    /**
     * Calls the reCAPTCHA siteverify API to verify whether the user passes
     * CAPTCHA test.
     *
     * @param string $remoteIp   IP address of end user.
     * @param string $response   response string from recaptcha verification.
     *
     * @return ReCaptchaResponse
     */
    public function verifyResponse($remoteIp, $response)
    {
        // Discard empty solution submissions
        if ($response == null || strlen($response) == 0) {
            $recaptchaResponse = new ReCaptchaResponse();
            $recaptchaResponse->success = false;
            $recaptchaResponse->errorCodes = 'missing-input';
            return $recaptchaResponse;
        }

        $getResponse = $this->_submitHttpGet(
            self::$_siteVerifyUrl,
            array (
                'secret' => $this->_secret,
                'remoteip' => $remoteIp,
                'v' => self::$_version,
                'response' => $response
            )
        );
        $answers = json_decode($getResponse, true);
        $recaptchaResponse = new ReCaptchaResponse();

        if (trim($answers ['success']) == true) {
            $recaptchaResponse->success = true;
        } else {
            $recaptchaResponse->success = false;
            $recaptchaResponse->errorCodes = $answers [error-codes];
        }

        return $recaptchaResponse;
    }
}
recaptchalib.php : classes ReCaptchaResponse et ReCaptcha
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
<!-- Partie client, dans <head></head> -->
<script src="https://www.google.com/recaptcha/api.js"></script>

<!-- Partie client, là où tu souhaites que le code soit affiché -->
<div class="g-recaptcha" data-sitekey="{{ entre guillemets, ta clé de site }}"></div>

<?php
// Partie serveur
require 'recaptchalib.php';

// La clé secrète est à donner ici en paramètre
$reCaptcha = new ReCaptcha($cleSecrete);

/** @var $response \ReCaptchaResponse */
$response = $reCAPTCHA->verifyResponse(
    $_SERVER["REMOTE_ADDR"],
    $values["g-recaptcha-response"]
);

if ($response->success) {
// …
Exemple d’utilisation
+0 -0

Non, c’est juste la couche qui permet à PHP d’ouvrir des connexions HTTPS par divers moyens, notamment file_get_contents(). Apparemment, c’est directement et uniquement dépendant de l’extension php_openssl, qui n’est donc pas forcément activée. A vérifier avec un phpinfo.

+0 -0

Salut,

J’ai regardé les captcha ’fait main’, mais rentrer un nombre, un text déformé etc… je suis la première que ça saoule !!

Du coup je me demande si 1 ou 2 champs cachés par css ne suffiraient pas ? Parce que si c’est un robot, il devrait remplir les champs quand même non ?

Bon, le souci n’est pas au niveau de PHP, mais un timeout de connexion. Vu que le problème persiste depuis bientôt une semaine, ce n’est plus imputable à du mauvais code ou Google. Je tenterais de contacter Free dans ce cas.

+0 -0
Connectez-vous pour pouvoir poster un message.
Connexion

Pas encore membre ?

Créez un compte en une minute pour profiter pleinement de toutes les fonctionnalités de Zeste de Savoir. Ici, tout est gratuit et sans publicité.
Créer un compte