dongsui0929 2013-01-21 09:24
浏览 44

登录Google Ingress

I am trying to login to Google account in order to be able to use Google Ingress Intel map in my own application. I found this question (Login to Google with PHP and Curl, Cookie turned off?) and I can login to Google Account, but problem starts when I want to load Ingress Intel map (http://www.ingress.com/intel), then I get this error:

Forbidden (403)

CSRF verification failed. Request aborted.

I know about CSRF but I dunno what I am doing wrong. Maybe it is because my cookie.txt file is empty, but why?

Here is my code:

$ch = curl_init();
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_COOKIEJAR, 'cookie.txt');
curl_setopt($ch, CURLOPT_COOKIEFILE, 'cookie.txt');
curl_setopt($ch, CURLOPT_HEADER, 0);  
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 120);
curl_setopt($ch, CURLOPT_TIMEOUT, 120);

curl_setopt($ch, CURLOPT_URL, 
  'https://accounts.google.com/ServiceLogin?hl=en&service=alerts&continue=http://www.google.com/alerts/manage');
$data = curl_exec($ch);

$formFields = getFormFields($data);

$formFields['Email']  = $USERNAME;
$formFields['Passwd'] = $PASSWORD;
unset($formFields['PersistentCookie']);

$post_string = '';
foreach($formFields as $key => $value) {
    $post_string .= $key . '=' . urlencode($value) . '&';
}

$post_string = substr($post_string, 0, -1);

curl_setopt($ch, CURLOPT_URL, 'https://accounts.google.com/ServiceLoginAuth');
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_string);

$result = curl_exec($ch);


    curl_setopt($ch, CURLOPT_URL, 'http://www.ingress.com/intel');
    curl_setopt($ch, CURLOPT_POST, 0);
    curl_setopt($ch, CURLOPT_POSTFIELDS, null);

    $result = curl_exec($ch);

    var_dump($result);


function getFormFields($data)
{
    if (preg_match('/(<form.*?id=.?gaia_loginform.*?<\/form>)/is', $data, $matches)) {
        $inputs = getInputs($matches[1]);

        return $inputs;
    } else {
        die('didnt find login form');
    }
}

function getInputs($form)
{
    $inputs = array();

    $elements = preg_match_all('/(<input[^>]+>)/is', $form, $matches);

    if ($elements > 0) {
        for($i = 0; $i < $elements; $i++) {
            $el = preg_replace('/\s{2,}/', ' ', $matches[1][$i]);

            if (preg_match('/name=(?:["\'])?([^"\'\s]*)/i', $el, $name)) {
                $name  = $name[1];
                $value = '';

                if (preg_match('/value=(?:["\'])?([^"\'\s]*)/i', $el, $value)) {
                    $value = $value[1];
                }

                $inputs[$name] = $value;
            }
        }
    }

    return $inputs;
}

Thanks for advice what I am doing wrong :)

  • 写回答

2条回答 默认 最新

  • dsdzz04802 2013-01-24 07:05
    关注
    <?php
    $username = 'email@gmail.com';
    $password = 'password';
    $cookies = 'cookies.txt';
    
    function getFormFields($data) {
            if(preg_match('/(<form.*?id=.?gaia_loginform.*?<\/form>)/is', $data, $matches)) {
                    $inputs = getInputs($matches[1]);
                    return $inputs;
            } else {
                    die('didnt find login form');
            }
    }
    
    function getInputs($form) {
            $inputs = array();
            $elements = preg_match_all('/(<input[^>]+>)/is', $form, $matches);
    
            if($elements > 0) {
                    for($i = 0; $i < $elements; $i++) {
                            $el = preg_replace('/\s{2,}/', ' ', $matches[1][$i]);
                            if (preg_match('/name=(?:["\'])?([^"\'\s]*)/i', $el, $name)) {
                                    $name  = $name[1];
                                    $value = '';
                                    if (preg_match('/value=(?:["\'])?([^"\'\s]*)/i', $el, $value)) {
                                            $value = $value[1];
                                    }
                                    $inputs[$name] = $value;
                            }
                    }
            }
            return $inputs;
    }
    
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
    curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.17 (KHTML, like Gecko) Chrome/24.0.1312.56 Safari/537.17");
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
    curl_setopt($ch, CURLOPT_COOKIEJAR, $cookies);
    curl_setopt($ch, CURLOPT_COOKIEFILE, $cookies);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 120);
    curl_setopt($ch, CURLOPT_TIMEOUT, 120);
    
    curl_setopt($ch, CURLOPT_URL, 'https://accounts.google.com/ServiceLogin?service=ah&passive=true&continue=https://appengine.google.com/_ah/conflogin%3Fcontinue%3Dhttp://www.ingress.com/intel');
    $data = curl_exec($ch);
    
    $formFields = getFormFields($data);
    $formFields['Email']  = $username;
    $formFields['Passwd'] = $password;
    unset($formFields['PersistentCookie']);
    
    $post_string = '';
    foreach($formFields as $key => $value) {
            $post_string .= $key . '=' . urlencode($value) . '&';
    }
    $post_string = substr($post_string, 0, -1);
    
    curl_setopt($ch, CURLOPT_URL, 'https://accounts.google.com/ServiceLoginAuth');
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $post_string);
    $result = curl_exec($ch);
    
    curl_setopt($ch, CURLOPT_URL, 'https://www.ingress.com/intel');
    curl_setopt($ch, CURLOPT_POST, 0);
    curl_setopt($ch, CURLOPT_POSTFIELDS, null);
    $result = curl_exec($ch);
    
    echo $result;
    
    curl_close($ch);
    @unlink($cookies);
    ?>
    
    评论

报告相同问题?