V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
aswid
V2EX  ›  PHP

PHP CURL 怎么模拟登录后抓取排行榜数据(http://www.appannie.com/apps/ios/top/china/overall)/?device= iPhone

  •  
  •   aswid · 2016-03-16 15:23:17 +08:00 · 2876 次点击
    这是一个创建于 2962 天前的主题,其中的信息可能已经有所发展或是发生改变。

    地址: http://www.appannie.com/apps/ios/top/china/overall/?device=iphone
    需要登录后才可以看到,怎么实现模拟浏览器登录?

    第 1 条附言  ·  2016-03-16 16:27:25 +08:00
    function HttpsPost($url, $data, $method = 'post', $cookie='') {
    $ch = curl_init();
    // 设置选项,包括 URL
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); // 对证书来源的检查
    // curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 1); // 从证书中检查 SSL 加密算法是否存在
    curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)"); // 模拟用户使用的浏览器
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转
    curl_setopt($ch, CURLOPT_AUTOREFERER, 1); // 自动设置 Referer
    curl_setopt($ch, CURLOPT_POST, 1); // 发送一个 常规的 Post 请求
    // curl_setopt($ch, CURLOPT_POSTFIELDS, $data); // Post 提交的数据包
    curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); //要提交的信息
    curl_setopt($ch, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环
    curl_setopt($ch, CURLOPT_HEADER, 0); // 显示返回的 Header 区域内容
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回

    $output = curl_exec($ch); // 执行操作
    if (curl_errno($ch)) {
    return "Errno" . curl_error($ch); // 捕抓异常
    }
    curl_close($ch); // 关闭 CURL
    return $output;
    }

    //获取登录所需参数
    $loginFormUrl = 'https://www.appannie.com/account/login';
    $loginForm = HttpsPost($loginFormUrl);

    $preg_csrfmiddlewaretoken = "/<input\s.*?name=\'csrfmiddlewaretoken\'.*?value=\'(.*?)\'.*?\/>/";
    $preg_next = "/<input\s.*?name=\"next\".*?value=\"(.*?)\".*?\/>/";
    preg_match($preg_csrfmiddlewaretoken, $loginForm, $match_csrfmiddlewaretoken);
    preg_match($preg_next, $loginForm, $match_next);

    $data['csrfmiddlewaretoken'] = $match_csrfmiddlewaretoken[1];
    $data['next'] = isset($match_next[1])?$match_next[1]:'/apps/ios/top/china/games/';
    $data['username'] = '**@**.com';
    $data['password'] = '******';
    $data['remember_user'] = 'on';

    $login = HttpsPost($loginFormUrl,$data,'post');

    //$login 提交登录失败
    6 条回复    2016-03-31 17:22:13 +08:00
    zhzhwcn
        1
    zhzhwcn  
       2016-03-16 18:01:26 +08:00
    Chrome 里开发人员工具里的 network 标签里看看有没有漏下的请求
    jugelizi
        2
    jugelizi  
       2016-03-16 18:50:57 +08:00
    你登录没 cookie 呀。。。。。。。
    aswid
        3
    aswid  
    OP
       2016-03-17 10:12:13 +08:00
    @jugelizi 保存的 cookie 应该不对所以一直登录失败
    cookie:
    # Netscape HTTP Cookie File
    # http://curl.haxx.se/docs/http-cookies.html
    # This file was generated by libcurl! Edit at your own risk.

    #HttpOnly_www.appannie.com FALSE / TRUE 0 sessionId ".eJxrYKotZNQI5S9OLS7OzM-LT81LTMpJTfFmChVIzEktKolPzkhNzo4vycxNLWRKTkksSQUxueCMQuZQLvYHzIJMvLwsnSLJBZUlVVzxoSHOXIUsmkGFrG1BhWyh3CX5xfGlBSA9KYXsnaV6AAqvJl4:1agNR3:N88XBiDLzuCkRN8ybuY5GhajWnU"
    .appannie.com TRUE / FALSE 1458180793 aa_user_token
    www.appannie.com FALSE / TRUE 1489630393 csrftoken nnMCiTASiomihPM9xqwgVzJep84jHacI
    aswid
        4
    aswid  
    OP
       2016-03-17 10:13:25 +08:00
    @zhzhwcn appannie 登录有 cookie 验证,cookie 不正确则无法登录成功,我保存的 cookie 有问题,不知道该怎么做
    aswid
        5
    aswid  
    OP
       2016-03-17 10:48:10 +08:00
    <?php

    function HttpsPost($url, $data = []) {
    $ch = curl_init();
    //设置选项,包括 URL
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); //对证书来源的检查
    curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.1.5) Gecko/20091102 Firefox/3.5.5"); //模拟用户使用的浏览器
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); //使用自动跳转
    curl_setopt($ch, CURLOPT_AUTOREFERER, 1); //自动设置 Referer
    curl_setopt($ch, CURLOPT_POST, 1); //发送一个 常规的 Post 请求
    curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); //要提交的信息
    curl_setopt($ch, CURLOPT_TIMEOUT, 30); //设置超时限制防止死循环
    curl_setopt($ch, CURLOPT_HEADER, 0); //显示返回的 Header 区域内容
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //获取的信息以文件流的形式返回

    curl_setopt($ch, CURLOPT_COOKIEFILE, dirname(__FILE__) . '/curl.cookie');
    curl_setopt($ch, CURLOPT_COOKIEJAR, dirname(__FILE__) . '/curl.cookie');

    $output = curl_exec($ch); //执行操作
    if (curl_errno($ch)) {
    return "Errno" . curl_error($ch); //捕抓异常
    }
    curl_close($ch); //关闭 CURL
    return $output;
    }

    //获取登录所需参数
    $loginFormUrl = 'https://www.appannie.com/account/login';
    //设置 cookie 保存路径
    $loginForm = HttpsPost($loginFormUrl, []);

    $preg_csrfmiddlewaretoken = "/<input\s.*?name=\'csrfmiddlewaretoken\'.*?value=\'(.*?)\'.*?\/>/";
    $preg_next = "/<input\s.*?name=\"next\".*?value=\"(.*?)\".*?\/>/";
    preg_match($preg_csrfmiddlewaretoken, $loginForm, $match_csrfmiddlewaretoken);
    preg_match($preg_next, $loginForm, $match_next);

    //设置 post 的数据
    $post['csrfmiddlewaretoken'] = $match_csrfmiddlewaretoken[1];
    $post['next'] = isset($match_next[1]) ? $match_next[1] : '/apps/ios/top/china/games/';
    $post['username'] = '***@***.com';
    $post['password'] = '******';
    $post['remember_user'] = 'on';

    //提交登录
    $loginPost = HttpsPost($loginFormUrl, $post);//未登录成功


    //获取信息
    $url2 = 'http://www.appannie.com/apps/ios/top/china/games/?device=iphone';
    $iphone_china = HttpsPost($loginFormUrl);
    echo $iphone_china;
    ppto
        6
    ppto  
       2016-03-31 17:22:13 +08:00
    php 内核代码在线查看工具, www.phpsourcechm.com 不用只为了看内核代码在本地装 ide 了 s
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3222 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 13:13 · PVG 21:13 · LAX 06:13 · JFK 09:13
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.