微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在网站中禁用自动登录-Android Studio

如何解决如何在网站中禁用自动登录-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 举报,一经查实,本站将立刻删除。