0

PHPでCURLを使用してVimeo.comにログインしようとしています。Vimeoログイン

CURLが使用するデータ(Cookieとフィールドデータ)を提供するために、ブラウザー拡張機能を使用してWebページからフィールドデータを読み取り、Cookieを取得しています。次に、そのデータをサーバーに渡し、curlを使用してログインしようとしています。

ブラウザー拡張機能の部分が正しく機能する(正しいデータを取得する)ことは非常に肯定的です。これは、通過するものと通過する必要があるものを確認でき、正しく一致するためです。

さらに、私はこれを他のサイトでも使用しており、ログインに問題はありませんが、vimeoではexecがを返しますfalse

何かご意見は?

function curlpage(){
    $ch = curl_init();
    $url = $this->input->post('url');
    $data = $this->input->post('data');
    $cookie = $this->input->post('cookie');
    $method = $this->input->post('method');
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_POSTFIELDS,$data);
    if(strtolower($method)=="put"){
        curl_setopt($ch, CURLOPT_PUT, 1);
    }
    else{
        curl_setopt($ch, CURLOPT_PUT, 0);
    }
    if(strtolower($method)=="get"){
        curl_setopt($ch, CURLOPT_HTTPGET, 1);
    }
    else{
        curl_setopt($ch, CURLOPT_HTTPGET, 0);
    }
    if(strtolower($method)=="post"){
        curl_setopt($ch, CURLOPT_POST, 1);
    }
    else{
        curl_setopt($ch, CURLOPT_POST, 0);
    }
    curl_setopt($ch, CURLOPT_FAILONERROR, true);
    curl_setopt($ch, CURLOPT_UNRESTRICTED_AUTH, true);
    curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_ANY);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
    curl_setopt($ch, CURLOPT_CAINFO, getcwd().'/certificates/BuiltinObjectToken-EquifaxSecureCA.crt');
    curl_setopt($ch, CURLOPT_HEADER, 1);
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
    curl_setopt($ch, CURLOPT_COOKIE, $cookie);
    curl_setopt($ch, CURLOPT_VERBOSE, 1);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:17.0) Gecko/20100101 Firefox/17.0");
    curl_setopt($ch, CURLOPT_REFERER, $url);
    $error = curl_error($ch);
    $url=curl_getinfo($ch, CURLINFO_EFFECTIVE_URL);
    if(!preg_match('/^http(s)?:\/\//', $url)){
        $url = 'http://' . $url;
    }
    $host = parse_url($url, PHP_URL_HOST);
    $page = curl_exec($ch);
    curl_close($ch);
    return array('page'=>$page, 'url'=>$host, 'error'=>$error);
}

これが私のサーバー上の上記の関数に送信しているデータのサンプルです(偽の電子メールとパスワードと変更されたCookieを使用):

data = action%253Dlogin%2526service%253Dvimeo%2526email%253Dhou%2540fah.com%2526password%253Dudwt%2526token%253D6b2fc081bcdf02b1f58a390d6a3f8b83
cookie = __ utma%3D18392654.1284111214.1456668252.1456678435.1456181183.3%3B__utmb%3D18302654.2.10.1454681883%3B__utmc%3D18232154%3B__utmz%3D17202654.1456675435.2.2.utmcsr%3Dgoogle%7Cutmccn%3 (%2520提供ではありません)%3B
method = POST
url = http%3A%2F%2Fvimeo.com%2Flog_in
4

2 に答える 2

1
$ret = customSendDataByCurl("https://vimeo.com/log_in");
preg_match("/xsrft: \'(.*)\',/i",$ret,$token);
$token = $token[1];
echo "$token <hr>";

$cookie = '(copy from your browser using tamper data)... xsrft='.$token;

$headers = array(
    "Referer: https://vimeo.com/log_in",
    "User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:26.0) Gecko/20100101 Firefox/26.0",
    "Accept: application/json",
    "Accept-Language: en-US,en;q=0.5",
    "X-Requested-With: XMLHttpRequest",
    "X-Request: JSON",
    "Content-Type: application/x-www-form-urlencoded; charset=utf-8",
);
$ret = customSendDataByCurl("https://vimeo.com/log_in?action=warm", "POSTDATA=email=(email url encoded)&token=".$token, $headers, $cookie);


$fields = array(
    "action" => "login",
    "service" => "vimeo",
    "email" => "(email)",
    "password" => "(pass)",
    "token" => $token,
);
$headers = array(
    "Referer: https://vimeo.com/log_in",
    "User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:26.0) Gecko/20100101 Firefox/26.0",
    "Content-Type: application/x-www-form-urlencoded; charset=utf-8",
);
$ret = customSendDataByCurl("https://vimeo.com/log_in", http_build_query($fields), $headers, $cookie);
$ret = customSendDataByCurl("https://vimeo.com/stats/video/84142281/totals/export:csv", http_build_query($fields), $headers, $cookie);
var_export($ret);

function customSendDataByCurl($agateway, $apostfields=null, $headers=array(), $cookie="") {
    if(is_array($apostfields)) $apostfields = http_build_query($apostfields);

    $cookiesFile = 'cookies.txt';

    $ch = curl_init($agateway);
    curl_setopt($ch, CURLOPT_HEADER, 1);
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
curl_setopt ($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
    curl_setopt( $ch, CURLOPT_COOKIESESSION, true );
    if ($headers) curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
    curl_setopt( $ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.3; WOW64; rv:26.0) Gecko/20100101 Firefox/26.0' );
    curl_setopt($ch,CURLOPT_COOKIEJAR,$cookiesFile);
    curl_setopt($ch,CURLOPT_COOKIEFILE,$cookiesFile);
    curl_setopt($ch, CURLOPT_COOKIE, $cookie);
    if(!empty($apostfields)) curl_setopt($ch, CURLOPT_POSTFIELDS, $apostfields);

    $response = curl_exec($ch);

    if(!$response) $response="CURL #".curl_errno($ch).": ".curl_error($ch);
    return $response;
}
于 2014-01-17T23:07:35.077 に答える
0

Vimeo、私は実際にWebサイトの奇妙なケースであることがわかりました。すべてのCookieを事前に設定するのではなく、フォームの送信時にログインに必要な特定のCookieを設定します。そのため、私の問題の1つは、正しいCookie情報のすべてを送信していなかったことです。

2つ目の問題は、送信時にデータが正しくエンコードされていなかったことです。

すべてが言われ、完了しました、私は今それを機能させることができました!

于 2013-01-06T11:29:51.283 に答える