duanang58939 2015-10-23 03:32
浏览 25
已采纳

如何使用php登录网页,导航和下载csv文件?

I want to write a php script that:

A. logs into a web site B. navigates to specific page (which is a csv file download) C. store the results in a string.

Something like:

$site->connect("dashboard.site.com");
$site->post_vars(array("username"=>"mike","password"=>"2345");
$csv_file = $site->download("dashboard.site.com/file.csv");

I've read about the snoopy class, but documentation seems to not exist so I can't be sure if this is something it can do.

  • 写回答

1条回答 默认 最新

  • dtp87205 2015-10-23 17:42
    关注

    I figured out how to use Curl to do it. My own login and password and merchant group of course are hidden in this code. But here's how to do it: I hope this helps anyone in the same situation.

    $cookie_jar = tempnam('/tmp','cookie');
    
    // log in
    $c = curl_init('https://dashboard.powerreviews.com/dashboard/login');
    curl_setopt($c, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($c, CURLOPT_COOKIEJAR, $cookie_jar);
    curl_setopt($c, CURLOPT_FOLLOWLOCATION, false);
    $page = curl_exec($c);
    curl_close($c);
    
    $post_fields = array("j_username" => "USERNAME", "j_password" => "PASSWORD", "command"=>"Login");
    $post_data = http_build_query($post_fields);
    
    $c = curl_init('https://dashboard.powerreviews.com/process_login');
    curl_setopt($c, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($c, CURLOPT_COOKIEFILE, $cookie_jar);
    curl_setopt($c, CURLOPT_COOKIEJAR, $cookie_jar);
    curl_setopt($c, CURLOPT_POST, true);
    curl_setopt($c, CURLOPT_FOLLOWLOCATION, true);
    curl_setopt($c, CURLOPT_POSTFIELDS, $post_data);
    $page = curl_exec($c);
    curl_close($c);
    
    // switch to Reviews Account
    $c = curl_init('https://dashboard.powerreviews.com/programs/epc?accessMerchantGroup=xxxxx');
    curl_setopt($c, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($c, CURLOPT_COOKIEFILE, $cookie_jar);
    curl_setopt($c, CURLOPT_COOKIEJAR, $cookie_jar);
    $csv_file = curl_exec($c);
    curl_close($c);
    
    
    // download RA unsubscribes
    $c = curl_init('https://dashboard.powerreviews.com/dashboard/unsubscribes.csv');
    curl_setopt($c, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($c, CURLOPT_COOKIEFILE, $cookie_jar);
    curl_setopt($c, CURLOPT_COOKIEJAR, $cookie_jar);
    $csv_file = curl_exec($c);
    curl_close($c);
    echo $csv_file;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow