0

curl を使用して Cookie を渡す際に、かなり興味深い問題があります。会社のキュー システムにログインし、成功したログインから Cookie を取得するスクリプトがあります。その後、スクリプトはこれらの Cookie を呼び出して、システムにクエリを実行し、出力を解析します。スクリプトは localhost では問題なく動作しますが、会社のサーバーに移行すると動作しません。Cookie ファイルを作成していますが、すべてのファイルサイズ = 0 バイトです。これはパーミッションの問題だと思いますが、その方法がわかりません (ファイルを chmod 777 するところまで行きました)。最も奇妙なことは、fwrite() を使用して任意のファイルに追加できることです。ここでデバッグを開始する場所がよくわからないので、誰かがアイデアを持っていることを願っています. 以下は、関連するコード スニペットです。

[syntax=php]

main class{

include_once('../shared_data/cquserdata.php');
$ckfile_name = tempnam('temp/', sha1('CqAuth'));
$ckfile = fopen($ckfile_name, 'w') or die('Derp...open...nooooooooo!');

cqUserData::cqLogin($credentials['username'],$credentials['pass'],$ckfile);

(skip a few thousand lines)
$puname = sanitizers::sanitize($_POST['puname']); //sanitize post input
$manager = cqUserData::getManager($puname, $ckfile);


}

cqLogin($username, $pass, $ckfile){

$url = 'URL';

        $options = array(

            CURLOPT_RETURNTRANSFER => true,     // return web page
            CURLOPT_HEADER         => false,    // don't return headers
            CURLOPT_FOLLOWLOCATION => true,     // follow redirects
            CURLOPT_ENCODING       => "",       // handle all encodings
            CURLOPT_AUTOREFERER    => true,     // set referer on redirect
            CURLOPT_CONNECTTIMEOUT => 120,      // timeout on connect
            CURLOPT_TIMEOUT        => 120,      // timeout on response
            CURLOPT_MAXREDIRS      => 10,       // stop after 10 redirects
            CURLOPT_SSL_VERIFYHOST => 0,
            CURLOPT_SSL_VERIFYPEER => 0,
            CURLOPT_USERAGENT      => 'uuberness',
            CURLOPT_COOKIEJAR     => $ckfile,
            CURLOPT_POSTFIELDS     => "redirect=&username=$username&password=$pass" //derp

        );

        $ch      = curl_init( $url );
        curl_setopt_array( $ch, $options );
        $content = curl_exec( $ch );
        $err     = curl_errno( $ch );
        $errmsg  = curl_error( $ch );
        $header  = curl_getinfo( $ch );
        curl_close( $ch );

        return true;

}

getManager($user,$ckfile){

$url = "URL"';

        $options = array(

            CURLOPT_RETURNTRANSFER => true,     // return web page
            CURLOPT_HEADER         => false,    // don't return headers
            CURLOPT_FOLLOWLOCATION => true,     // follow redirects
            CURLOPT_ENCODING       => "",       // handle all encodings
            CURLOPT_AUTOREFERER    => true,     // set referer on redirect
            CURLOPT_CONNECTTIMEOUT => 120,      // timeout on connect
            CURLOPT_TIMEOUT        => 120,      // timeout on response
            CURLOPT_MAXREDIRS      => 10,       // stop after 10 redirects
            CURLOPT_SSL_VERIFYHOST => 0,
            CURLOPT_SSL_VERIFYPEER => 0,
            CURLOPT_USERAGENT      => 'uuberness',
            CURLOPT_COOKIEFILE     => $ckfile,
            CURLOPT_POSTFIELDS     => "username=$user&usernamecheck=1" //derp

        );

        $ch      = curl_init( $url );
        curl_setopt_array( $ch, $options );

        $content = curl_exec( $ch );
        $err     = curl_errno( $ch );
        $errmsg  = curl_error( $ch );
        $header  = curl_getinfo( $ch );

        curl_close( $ch );

        $header['errno']   = $err;
        $header['errmsg']  = $errmsg;
        $header['content'] = $content;
        $header['data'] = $data;

        $doc = new DOMDocument;

        $doc->loadHTML($content);
        $doc->preserveWhiteSpace = false;
        $tables = $doc->getElementsByTagName('table');

        foreach($tables as $table){

            ***Code excluded, loops rows to find correct, then defines manager**

            $manager = $manager[1];


        }

        return $manager;

}

[/syntax]

この時点で、Cookie のヘッダーを解析して操作することを試みるのは良い考えかもしれないと考えています....しかし、それは理想的とは言えません。どんな提案でも大歓迎です:D

ありがとうございました!

4

1 に答える 1

1

ご挨拶、

それで私は問題が何であるかを理解しました。fopen()でファイルを開いてから、ファイルハンドラーをcURLに渡していました。私がすべきことは、完全なファイルパス+名前をcURLに渡すことです。コードの修正された部分:

$ckfile = dirname(__FILE__) . "/". sha1($username);
于 2011-04-17T02:01:23.367 に答える