問題陳述:
儘管使用了正確的登入憑證,
<code class="java">public void connect() { try { Connection.Response loginForm = Jsoup.connect("https://www.capitaliq.com/CIQDotNet/Login.aspx/login.php") .method(Connection.Method.GET) .execute(); org.jsoup.nodes.Document document = Jsoup.connect("https://www.capitaliq.com/CIQDotNet/Login.aspx/authentication.php") .data("cookieexists", "false") .data("username", "myUsername") .data("password", "myPassword") .cookies(loginForm.cookies()) .post(); System.out.println(document); } catch (IOException ex) { Logger.getLogger(WebCrawler.class.getName()).log(Level.SEVERE, null, ex); } }</code>
儘管使用了正確的登入憑證,但下面發佈的Jsoup 程式碼無法登入目標網站,而是顯示登入頁面的HTML程式碼。
解決方案:
<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>
除了使用者名稱、密碼和cookie之外,目標網站需要兩個附加值來登入:VIEWSTATE 和 EVENTVALIDATION。要取得這些值:
<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>
然後,將這些值加入發布請求(順序無關緊要):
<code class="java">.data("myLogin$myEnableAutoLogin", "on")</code>
要啟用「記住我」功能,請新增:
完成這些修改後,登入現在應該如預期般成功。以上是如何解決因缺少 VIEWSTATE 和 EVENTVALIDATION 參數而導致的 Jsoup 登入表單提交問題?的詳細內容。更多資訊請關注PHP中文網其他相關文章!