Google Recaptcha API POST请求给出403禁止错误

时间:2019-08-15 07:44:28

标签: php post recaptcha http-status-code-403 fsockopen

POST请求为以下请求提供了禁止的错误。

Google代码存档https://storage.googleapis.com/google-code-archive-downloads/v2/code.google.com/recaptcha/recaptcha-php-1.11.zip中的代码

功能调用如下

$response = _recaptcha_http_post (RECAPTCHA_VERIFY_SERVER, "/recaptcha/api/siteverify",
                                      array (
                                             'privatekey' => $privkey,
                                             'remoteip' => $remoteip,
                                             'response' => $response
                                             ) + $extra_params
                                      );

功能在下方

function _recaptcha_http_post($host, $path, $data, $port = 80) {

    $req = _recaptcha_qsencode ($data);

    $http_request  = "POST $path HTTP/1.0\r\n";
    $http_request .= "Host: $host\r\n";
    $http_request .= "Content-Type: application/x-www-form-urlencoded;\r\n";
    $http_request .= "Content-Length: " . strlen($req) . "\r\n";
    $http_request .= "User-Agent: reCAPTCHA/PHP\r\n";
    $http_request .= "\r\n";
    $http_request .= $req;

    echo "HTTP_Request - ";
    echo $http_request;

    $response = '';
    if( false == ( $fs = @fsockopen($host, $port, $errno, $errstr, 10) ) ) {
            die ('Could not open socket');
    }

    fwrite($fs, $http_request);

    while ( !feof($fs) )
            $response .= fgets($fs, 1160); // One TCP-IP packet
    fclose($fs);
    echo "HTTP_Response - ";
    echo $response;
    $response = explode("\r\n\r\n", $response, 2);


    return $response; }

以下请求和响应

HTTP_Request = POST / recaptcha / api / siteverify HTTP / 1.0主机:www.google.com内容类型:application / x-www-form-urlencoded;内容长度:418的User-Agent:验证码/ PHP专用密钥= 6LdWx7AUAAAAANcawRDmFaZ3mto2mR9BPxuO5Q7V&REMOTEIP = 91.75.176.244&响应= 03AOLTBLRSaTq0r_J2gVWzsmxtidDnGAIeIpfM8jga9qmMD9rfKFm-cymLoT6dWhJjAimn7RmPOx1IPTLoUeiAXS1m8qobI8Yk_kPtmPHRm17lxsFbOKMG6b5-nldm4sSNohW02zz9D0sDkymEnGWXej3bTczvv2ah1PePJCIBG-3Ae0IuJP2EwvD4AXtj5mFXZdomcBqe1zGLny4aiO6-KcRy73MRkvGLYxiWGd8BeV3wQvwTPJWhlsoAQjEtBqwFOnbc9ifeWGrMlXCkcXJRGJBsWUqKZ9VkqeKfs00O4RWN9TYDp7d1DGbQFdj7d5iUIpK4MIIRWJeE

HTTP_Response = HTTP / 1.0 403禁止的内容类型:text / html; charset = UTF-8日期:格林尼治标准时间2019年8月15日星期四过期:格林尼治标准时间2019年8月15日星期四07:30:28缓存控制:私有,最大年龄= 0 X内容类型选项: nosniff X-Frame-Options:SAMEORIGIN X-XSS-Protection:1; mode = block服务器:GSE接受范围:无变化:接受编码

1 个答案:

答案 0 :(得分:0)

403错误是由于从请求服务器阻止的出站 https 连接引起的。 服务器设置中允许https连接时。错误消失了。

使用以下代码代替可达性库。

function isValid() {try {

    $url = 'https://www.google.com/recaptcha/api/siteverify';
    $data = ['secret'   => 'YOUR SECRET KEY',
             'response' => $_POST['g-recaptcha-response'],
             'remoteip' => $_SERVER['REMOTE_ADDR']];

    $options = [
        'http' => [
            'header'  => "Content-type: application/x-www-form-urlencoded\r\n",
            'method'  => 'POST',
            'content' => http_build_query($data) 
        ]
    ];

    $context  = stream_context_create($options);
    $result = file_get_contents($url, false, $context);
    return json_decode($result)->success;
}
catch (Exception $e) {
    echo "Exception";
    return null;
}

}