1

Web サイトにログインするための簡単なコードを作成しました。

private function request($url, $reset_cookies, $post_data)
  {

    $options = array(
      CURLOPT_URL               => $url,
      CURLOPT_RETURNTRANSFER    => 1,
      CURLOPT_HEADER            => 0,
      CURLOPT_FAILONERROR       => 1,
      CURLOPT_USERAGENT         => $this->user_agent,
      CURLOPT_CONNECTTIMEOUT    => 30,
      CURLOPT_TIMEOUT           => 30,
      CURLOPT_SSL_VERIFYPEER    => 0,   
      CURLOPT_FOLLOWLOCATION    => 1,
      CURLOPT_MAXREDIRS         => 10,
      CURLOPT_AUTOREFERER       => 1,
      CURLOPT_COOKIESESSION     => $reset_cookies ? 1 : 0,
      CURLOPT_COOKIEJAR         => $this->session_id,
      CURLOPT_COOKIEFILE        => $this->session_id,
    );

    // Add POST data
    if (isset($post_data))
    {
      $options[CURLOPT_CUSTOMREQUEST] = 'POST';
      $options[CURLOPT_POST]          = 1;
      $options[CURLOPT_POSTFIELDS]    = http_build_query($post_data);
    }

    // Attach options
    curl_setopt_array($this->curl, $options);

    // Execute the request and read the response
    $content = curl_exec($this->curl);

    // Handle any error
    if (curl_errno($this->curl)) throw new Exception(curl_error($this->curl));

    return $content;
  }

したがって、基本的に、私のログイン システムの通常の手順は次のようになります。

  1. GET 要求を送信してセキュリティ トークンを取得し、Cookie セッションを初期化します。(完了して動作中)

    $security_token = $this->browser->request('https://mysite.com/login', true, null);
    
  2. ユーザー名、パスワード、およびセキュリティ トークンを含む POST 要求を送信します。

    $postdata = array(
        'login' => $login,
        'password' => $password,
        '__RequestVerificationToken' => $security_token,
    );
    $login_page = $this->browser->request('https://mysite.com/login', false, $postdata);
    

ステップ 2 で、コンテンツの長さが必要であるという 411 エラーが発生しました。

何か間違えたのでしょうか、それともパラメータを設定するのを忘れましたか?

4

1 に答える 1

2

解決策は、この行を削除することでした

$options[CURLOPT_CUSTOMREQUEST] = 'POST';
于 2014-02-25T19:44:00.843 に答える