使用Java URLConnection的Cookie管理

使用Java URLConnection的Cookie管理,第1张

概述我对android编程非常陌生,最近成功实现了成功的HTTPPost请求,只是得知在后续的Post/Get请求之间没有存储我的cookie.我环顾了互联网,发现了一些Android的Apache客户端和Java的HttpURLConnection的示例.我无法在当前类中实现这两种方法,因此我想知道是否有更多经验的人可以查看我

我对android编程非常陌生,最近成功实现了成功的http Post请求,只是得知在后续的Post / Get请求之间没有存储我的cookie.我环顾了互联网,发现了一些Android的Apache客户端和Java的httpURLConnection的示例.我无法在当前类中实现这两种方法,因此我想知道是否有更多经验的人可以查看我的代码并提出建议.

概括:

>我的初始POST请求成功并通过了身份验证.
>我的第二个POST请求没有保留初始POST请求中的cookie.
>是否存在任何特定的实例或原因,为什么有人会选择Apache方法或Java实现?两者都是平等的,还是一个比另一个提供更多的功能和灵活性?

任何帮助表示赞赏,谢谢.

webCreate.java

import androID.util.Log;import java.io.BufferedReader;import java.io.DataOutputStream;import java.io.inputStreamReader;import java.net.cookieHandler;import java.net.cookieManager;import java.net.httpcookie;import java.net.httpURLConnection;import java.net.URL;import javax.net.ssl.httpsURLConnection;public class webCreate {    private final String USER_AGENT = "Mozilla/5.0";    // http GET request    public voID sendGet(String url) throws Exception {        cookieManager cookieManager = new cookieManager();        cookieHandler.setDefault(cookieManager);        httpcookie cookie = new httpcookie("lang", "en");        URL obj = new URL(url);        httpURLConnection con = (httpURLConnection) obj.openConnection();        // optional default is GET        con.setRequestMethod("GET");        //add request header        con.setRequestProperty("User-Agent", USER_AGENT);        int responseCode = con.getResponseCode();        Log.d("sendGet", "\nSending 'GET' request to URL : " + url);        BufferedReader in = new BufferedReader(                new inputStreamReader(con.getinputStream()));        String inputline;        StringBuffer response = new StringBuffer();        while ((inputline = in.readline()) != null) {            response.append(inputline);        }        in.close();        //print result        System.out.println(response.toString());        Log.d("Response Code", response.toString());    }    // http POST request    String  sendPost(String url, String urlParams) throws Exception {        cookieManager cookieManager = new cookieManager();        cookieHandler.setDefault(cookieManager);        httpcookie cookie = new httpcookie("lang", "en");        URL obj = new URL(url);        httpsURLConnection con = (httpsURLConnection) obj.openConnection();        //add request header        con.setRequestMethod("POST");        con.setRequestProperty("User-Agent", USER_AGENT);        con.setRequestProperty("Accept-Language", "en-US,en;q=0.5");        // Send post request        con.setDoOutput(true);        DataOutputStream wr = new DataOutputStream(con.getoutputStream());        wr.writeBytes(urlParams);        wr.flush();        wr.close();        int responseCode = con.getResponseCode();        System.out.println("\nSending 'POST' request to URL : " + url);        System.out.println("Post parameters : " + urlParams);        System.out.println("Response Code : " + responseCode);        BufferedReader in = new BufferedReader(                new inputStreamReader(con.getinputStream()));        String inputline;        StringBuffer response = new StringBuffer();        while ((inputline = in.readline()) != null) {            response.append(inputline);        }        in.close();        System.out.println("Response Code : " + response);        return  response.toString();    }}

解决方法:

您需要在每个调用外部维护cookie上下文,并提供相同的cookie存储在后续的GET和POST中. Java实现和Apache实现都是相同的.

以我的经验,Apache’s HTTP components优于内置的Java实现.我花了大量时间尝试使用Java的实现编写实用程序,我最大的问题是超时.错误的Web服务器将挂起,导致连接无限期挂起.切换到Apache之后,超时是可调整的,并且我们没有更多的挂起线程.

我将举一个使用Apache的例子.

在您的父方法中创建cookieStore实例:

cookieStore cookieStore = new BasiccookieStore();

然后在您的GET或POST实现中传递cookieStore实例,并在构建httpClIEnt时使用它:

public voID sendGet(String url, cookieStore cookieStore) throws Exception {    ...    httpClIEnt clIEnt = httpClIEntBuilder.create().setDefaultcookieStore(cookieStore).build();    httpGet request = new httpGet(uri);  // or httpPost...    request.addheader("User-Agent", USER_AGENT);    httpResponse response = clIEnt.execute(request);    BufferedReader br = new BufferedReader(new inputStreamReader(response.getEntity().getContent()));    ...}

AndroID扩展了java.net.httpURLConnection并建议使用它,因此我还将对此进行概述.

httpURLConnection和httpsURLConnection自动透明地使用cookieHandler中设置的cookieManager. cookieHandler在VM范围内,因此只能设置一次.如果像在代码中那样为每个请求创建一个新的cookieManager,它将清除先前请求中设置的所有cookie.

您不需要自己创建httpcookie的实例.当httpURLConnection从服务器接收cookie时,cookieManager将接收cookie并将其存储.将来对同一服务器的请求将自动发送先前设置的cookie.

因此,请将此代码移至您的应用程序设置,使其仅发生一次:

cookieManager cookieManager = new cookieManager();cookieHandler.setDefault(cookieManager);
总结

以上是内存溢出为你收集整理的使用Java URLConnection的Cookie管理全部内容,希望文章能够帮你解决使用Java URLConnection的Cookie管理所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1092995.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-28
下一篇2022-05-28

发表评论

登录后才能评论

评论列表(0条)

    保存