ホームページ  >  記事  >  バックエンド開発  >  Jsoup でログイン フォームを送信する際の認証の問題を解決する方法

Jsoup でログイン フォームを送信する際の認証の問題を解決する方法

DDD
DDDオリジナル
2024-10-20 13:18:30567ブラウズ

How to Overcome Authentication Issues While Submitting Login Forms with Jsoup

Jsoup でログイン フォームを送信する際に発生する問題

有効なログイン資格情報を入力したにもかかわらず、提供されたコードを使用してサイトにアクセスするときに問題が発生する場合があります。実行時に、コードは認証に失敗し、潜在的な問題を示しています。

考えられる見落としの 1 つは、ユーザー名、パスワード、Cookie 以外の追加値の要件に関係します。具体的には、サイトでは VIEWSTATE と EVENTVALIDATION を含める必要があります。

これに対処するには、最初の GET リクエストの応答から次の値を取得します。

<code class="java">Document doc = loginForm.parse();
Element e = doc.select("input[id=__VIEWSTATE]").first();
String viewState = e.attr("value");
e = doc.select("input[id=__EVENTVALIDATION]").first();
String eventValidation = e.attr("value");</code>

これらの値を後続の POST に組み込みます。 request:

<code class="java">org.jsoup.nodes.Document document = (org.jsoup.nodes.Document) Jsoup.connect("https://www.capitaliq.com/CIQDotNet/Login.aspx/authentication.php").userAgent("Mozilla/5.0")               
            .data("myLogin$myUsername", "MyUsername")
            .data("myLogin$myPassword, "MyPassword")
            .data("myLogin$myLoginButton.x", "22")                   
            .data("myLogin$myLoginButton.y", "8")
            .data("__VIEWSTATE", viewState)
            .data("__EVENTVALIDATION", eventValidation)
            .cookies(loginForm.cookies())
            .post();</code>

サイトのブラウザ固有のレンダリングとの互換性を確保するために userAgent フィールドを含めます。

機能拡張

「記憶する」を有効にするにはログイン時の「me」機能:

<code class="java">.data("myLogin$myEnableAutoLogin", "on")</code>

以上がJsoup でログイン フォームを送信する際の認証の問題を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。