在活动之间使用DefaultHttpClient

时间:2011-11-20 20:07:03

标签: java android cookies httpclient

我有一个DefaultHttpClient,它不检查我在两个活动中使用的证书:

public function clientWithoutCertificateCheck() {
    DefaultHttpClient httpClient = new DefaultHttpClient();
    try{
        KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
        trustStore.load(null, null);

        SSLSocketFactory sf = new MySSLSocketFactory(trustStore);
        sf.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);

        HttpParams params = new BasicHttpParams();
        HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
        HttpProtocolParams.setContentCharset(params, HTTP.UTF_8);

        SchemeRegistry registry = new SchemeRegistry();
        registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
        registry.register(new Scheme("https", sf, 443));

        ClientConnectionManager ccm = new ThreadSafeClientConnManager(params, registry);
        httpClient = new DefaultHttpClient(ccm, params);
    } catch (Exception e) { }

    return httpClient;
}

并且它会在同一活动中的页面上登录。

启动其他活动后,我保存了它的cookie:

CookieSyncManager.createInstance(this);
List<Cookie> cookies = httpClient.getCookieStore().getCookies();
for(Cookie cookie : cookies)
{
    String cookieString = cookie.getName() + "=" + cookie.getValue() + "; domain=" + cookie.getDomain();                        
    CookieManager.getInstance().setCookie(cookie.getDomain(), cookieString);  
}

然后我试图在另一个活动中获得相同的httpClient。

DefaultHttpClient httpClient = clientWithoutCertificateCheck();
String url = "https://academicos.unilasalle.edu.br/";
String[] keyValueSets = CookieManager.getInstance().getCookie(url).split(";");
for(String cookie : keyValueSets)
{
    String[] keyValue = cookie.split("=");
    String key = keyValue[0];
    String value = "";
    if(keyValue.length>1) value = keyValue[1];
    httpClient.getCookieStore().addCookie(new BasicClientCookie(key, value));
}

由于某种原因他不再登录了。

有人可以帮我解决这个问题吗?

1 个答案:

答案 0 :(得分:0)

根据您的代码,显然通过调用clientWithoutCertificateCheck()始终返回一个新创建的httpClient,而不是之前活动中的httpClient。因此,在服务器端,它可能认为这些是不同的传入连接并与不同的会话/ cookie相关联。

活动的生命周期非常短暂,通常在应用程序运行时间内多次创建/销毁。从我的角度来看,将httpClient绑定到Activity是不合理的。 如果您想保留/使用单个httpClient实例交叉avtivities,请考虑使用服务,将您的http相关内容实现/集中到您的HttpService中,并为需要使用http服务的所有活动启动/绑定服务。希望有所帮助。