问题描述
我正在编写一个应用程序,但是我有一个问题,我用Jsoup发出GET和POST请求以在Iliad网站上进行登录,当我运行该应用程序时,它也使用错误的凭据登录,我认为这是因为该网站进行了自动登录,但是我不知道如何删除它。
这是代码:
try {
res = Jsoup.connect("https://www.iliad.it/account/")
.method(Connection.Method.GET)
.header("Content-Type","application/x-www-form-urlencoded")
.ignoreHttpErrors(true)
//.cookie("auth_mobile","0")
.execute();
SESSID = res.cookie("ACCOUNT_SESSID");
//AUTH = res.cookie("auth_mobile");
response = Jsoup.connect("https://www.iliad.it/account/")
.method(Connection.Method.POST)
.header("Content-Type","application/x-www-form-urlencoded")
.data("login-ident",MainActivity.id)
.data("login-pwd",MainActivity.pwd)
.userAgent("Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0")
.ignoreHttpErrors(true)
.followRedirects(true)
.cookie("ACCOUNT_SESSID",SESSID)
//.cookie("auth_mobile","0")
.execute();
Errore = false;
doc = Jsoup.parse(response.parse().outerHtml());
System.out.println(doc);
} catch (Exception e) {...
解决方法
尝试从初始GET请求的标头中获取会话cookie:
set-cookie: ACCOUNT_SESSID=9p3lg...1j2e3; path=/account/; HttpOnly
在对服务器的任何后续请求中,必须将其设置为:
Cookie: ACCOUNT_SESSID=9p3lg...1j2e3
所以您应该有一些类似的东西:
response = Jsoup.connect("https://www.iliad.it/account/")
.method(Connection.Method.POST)
.data("login-ident",MainActivity.id)
.data("login-pwd",MainActivity.pwd)
...
.cookie("Cookie","ACCOUNT_SESSID=" + SESSID) // <<<
//.cookie("auth_mobile","0")
.execute();
这应该使您更近一步。