如何解决如何在网站中禁用自动登录-Android Studio
我正在编写一个应用程序,但是我有一个问题,我用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();
这应该使您更近一步。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。