ホームページ >バックエンド開発 >Python チュートリアル >Python は Srapy フレームワーク クローラーを使用してログインをシミュレートし、Zhihu コンテンツをクロールします

Python は Srapy フレームワーク クローラーを使用してログインをシミュレートし、Zhihu コンテンツをクロールします

WBOY
WBOYオリジナル
2016-07-22 08:56:301785ブラウズ

1. クッキーの原則
HTTPはステートレスな接続指向プロトコルであり、接続状態を維持するためにCookieメカニズムが導入されています
。 Cookie は http メッセージ ヘッダーの属性であり、次のものが含まれます:

  • Cookie名(Name) Cookie値(Value)
  • Cookieの有効期限(Expires/Max-Age)
  • Cookieアクションパス(パス)
  • Cookie が配置されているドメイン名 (Domain)、安全な接続に Cookie を使用する (Secure)

最初の 2 つのパラメータは、Cookie の適用に必要な条件です。さらに、Cookie のサイズも含まれます (サイズ、ブラウザごとに Cookie の数とサイズの制限が異なります)。

2. 模擬ログイン
今回クロールしたメインWebサイトはZhihuです
Zhihu をクロールするにはログインする必要があります。以前の組み込み Python ライブラリを通じて、フォーム送信を簡単に実装できます。

それでは、Scrapy を介してフォーム送信を実装する方法を見てみましょう。

まずはログイン時にフォームの結果を確認します。先ほどの手法と同様に、意図的に間違ったパスワードを入力し、ログインページのヘッダーとフォームをキャプチャしました(Chrome付属の開発者ツールのネットワーク機能を使用しました)

201672182940777.png (702×170)

キャプチャされたフォームを見ると、4 つの部分があることがわかります:

  • メールアドレスとパスワードは個人ログイン用のメールアドレスとパスワードです
  • rememberme フィールドはアカウントを記憶するかどうかを示します
  • 最初のフィールドは _xsrf です。これは検証メカニズムだと思われます
  • あとは _xsrf だけが知りません。Web ページをリクエストするときにこの検証フィールドが必ず送信されると思いますので、現在の Web ページのソース コードを確認してみましょう (マウスを右クリックして Web ページのソース コードを表示するか、ショートカットキーを直接使用してください)

201672183128262.png (1788×782)

私たちの推測が正しかったかどうかを確認してください

これでフォームログイン関数を書くことができます

リーリー

主な機能は機能のコメントで説明しています
3. クッキーの保存
同じ状態を使用してウェブサイトを継続的にクロールするには、Cookie を保存し、Cookie を使用して状態を保存する必要があります。Scrapy は、直接使用できる Cookie 処理ミドルウェアを提供します。

クッキーミドルウェア:

この Cookie ミドルウェアは、Web サーバーによって送信された Cookie を保存および追跡し、次のリクエストでこの Cookie を送信します

Scrapy の公式ドキュメントには次のコード例が記載されています:

リーリー
次に、クローラー クラスのメソッドを変更して、Cookie を追跡できるようにします

リーリー

4. 頭を変装する
Web サイトにログインするには、ホットリンクを防ぐためのヘッダーの追加やサーバー ログインのシミュレートなど、ヘッダーの偽装が必要になる場合があります

201672183151347.png (2136×604)

保険の場合、次のようにヘッダーにさらに多くのフィールドを入力できます

リーリー
Scrapy では、Request と FormRequest の両方が初期化時にヘッダー フィールドを持ちます。ヘッダーはカスタマイズできるため、ヘッダー フィールドを追加できます。

ログイン関数の最終バージョンを形成する

リーリー

5. アイテムクラスとクロール間隔

Zhihu クローラー コードの完全なリンク
リーリー

クロール間隔を設定します。訪問中にクローラーのクロールが速すぎる場合、Web サイトのクローラー メカニズムがトリガーされます。 リーリー

詳細な設定については、公式ドキュメントをご覧ください
結果を確認してください (一部のみ)

リーリー

6. 問題点


ルール設計では Web サイトの完全なクロールを実現することはできませんが、簡単な質問のクロールのみを設定します

    Xpath 設定は厳密ではないため、再検討する必要があります
  • Unicode エンコードは UTF-8 に変換する必要があります
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。