0

我需要一个大约 2012 年的示例,说明如何使用 PHP cURL 登录 UPS。我不会在通话之间关闭会话。需要获取 3 个页面,1) 登录页面 2) 密码页面和 3) 发票页面

我以前有它的工作,但它不再。我删除了 cookie 文件,它工作了一段时间,然后我收到消息“由于不活动,您当前的请求已超时。您需要重新启动请求。” 如果我不在窗口内登录,即使成功登录也会超时。我尝试删除cookie文件并重新开始,但没有奏效。任何想法如何使它超时窗口是无限的?这是我的代码,已删除凭据:

              $cookie_file_path = "/tmp/cookie.txt";
              // remove previous cookie
              if (file_exists($cookie_file_path)) {
            `rm -fr {$cookie_file_path}`;
              } 
            $login_url = 'https://www.ups.com/one-to-one/login';
            $password_url = 'https://www.ups.com/one-to-one/password';
            $invoice_url = 'upsDOTcomSLASHviewbillSLASHinvoices';
            $agent = "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:10.0) Gecko/20100101 Firefox/10.0";

            $login_data = "sysid=null&lang=null&langc=null&method=null&returnto=null&loc=en_US&uid=<user_id>&rememberMe=1&next=Next&pm_fp=version%253D1%2526pm%255Ffpua%253Dmozilla%252F5%252E0%2520%2528windows%2520nt%25206%252E1%253B%2520wow64%253B%2520rv%253A10%252E0%2529%2520gecko%252F20100101%2520firefox%252F10%252E0%257C5%252E0%2520%2528Windows%2529%257CWin32%2526pm%255Ffpsc%253D24%257C1920%257C1200%257C1160%2526pm%255Ffpsw%253D%257Cqt6%257Cqt5%257Cqt4%257Cqt3%257Cqt2%257Cqt1%257Cswf%257Cpdf%257Cpdf%2526pm%255Ffptz%253D%252D5%2526pm%255Ffpln%253Dlang%253Den%252DUS%257Csyslang%253D%257Cuserlang%253D%2526pm%255Ffpjv%253D1%2526pm%255Ffpco%253D1";
            $password_data = "sysid=null&lang=null&langc=null&method=null&returnto=null&loc=en_US&password=<password>&next=Log+In&pm_fp=version%253D1%2526pm%255Ffpua%253Dmozilla%252F5%252E0%2520%2528windows%2520nt%25206%252E1%253B%2520wow64%253B%2520rv%253A10%252E0%2529%2520gecko%252F20100101%2520firefox%252F10%252E0%257C5%252E0%2520%2528Windows%2529%257CWin32%2526pm%255Ffpsc%253D24%257C1920%257C1200%257C1160%2526pm%255Ffpsw%253D%257Cqt6%257Cqt5%257Cqt4%257Cqt3%257Cqt2%257Cqt1%257Cswf%257Cpdf%257Cpdf%2526pm%255Ffptz%253D%252D5%2526pm%255Ffpln%253Dlang%253Den%252DUS%257Csyslang%253D%257Cuserlang%253D%2526pm%255Ffpjv%253D1%2526pm%255Ffpco%253D1";

            $headers[] = "Accept: */*";
            $headers[] = "Connection: Keep-Alive";
            $headers[] = "Content-Type: application/x-www-form-urlencoded";
            $ch = curl_init();
            curl_setopt($ch, CURLOPT_URL, $login_url);
            curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); 
            curl_setopt($ch, CURLOPT_USERAGENT, $agent);
            curl_setopt($ch, CURLOPT_POST, 1); 
            curl_setopt($ch, CURLOPT_POSTFIELDS, $login_data); 
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
            curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
            curl_setopt($ch, CURLOPT_REFERER, 'https://www.ups.com/myups/login'); 
            curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file_path);
            curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file_path); 
            ob_start();
            $result = curl_exec ($ch);
            ob_end_clean();
            echo curl_error($ch);   // prints nothing if successful
            //curl_close($ch);


            //$ch = curl_init();
            curl_setopt($ch, CURLOPT_URL, $password_url);
            curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/x-www-form-urlencoded'));
            curl_setopt($ch, CURLOPT_HEADER, 1);
            curl_setopt($ch, CURLOPT_USERAGENT, $agent); 
            curl_setopt($ch, CURLOPT_POST, 1); 
            curl_setopt($ch, CURLOPT_POSTFIELDS, $password_data); 
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
            curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); 
            curl_setopt($ch, CURLOPT_REFERER, $login_url); 
            curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file_path);
            curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file_path); 
            ob_start();
            $result = curl_exec ($ch);
            ob_end_clean();
            echo curl_error($ch)        // prints nothing if successful
            //curl_close($ch);


            //$ch = curl_init();
           curl_setopt($ch, CURLOPT_URL, $invoice_url);
           curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: text/html; charset=utf-8'));
           curl_setopt($ch, CURLOPT_HEADER, 1);
            curl_setopt($ch, CURLOPT_USERAGENT, $agent); 
            curl_setopt($ch, CURLOPT_POST, 1); 
            curl_setopt($ch, CURLOPT_POSTFIELDS, $invoice_data); 
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
            curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); 
            curl_setopt($ch, CURLOPT_REFERER, $password_url);
            curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file_path);
            curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file_path); 
            ob_start(); 
            $result = curl_exec ($ch);
            ob_end_clean();
            echo curl_error($ch);       // prints nothing if successful
            curl_close($ch);

即使在删除并重新创建 cookie 文件后,我也无法通过第一个登录页面,因为我得到了:

由于不活动,您当前的请求已超时。您将需要重新开始您的请求。

任何帮助表示赞赏。

4

2 回答 2

1
  1. 尝试从另一台服务器连接。也许你被列入黑名单。
  2. CURLOPT_FRESH_CONNECTCURLOPT_FORBID_REUSE卷曲选项。
  3. 在提交帖子数据之前访问登录页面
于 2012-02-15T09:16:19.843 回答
0

是的,我很无聊,但这就是为什么你不应该这样做。

UPS 技术协议 1.2 f:

自动访问。不受限制地,通过自动查询设备、机器人或具有类似功能的重复数据收集和提取工具、例程、脚本或其他机制对 UPS 系统或托管 UPS 技术的任何访问,其本身并非 UPS 技术许可用于本协议下的此类目的,均明确表示禁止。

于 2012-02-14T01:15:20.260 回答