[Android实例] android登录Web以及登录保持,cookie管理相关

对于登录功能本身没有任何特别,使用httpclient向服务器post用户名密码即可。
但是为了保持登录的状态(在各个Activity之间切换时要让网站知道用户一直是处于登录的状态)就需要进行cookie的读写。
httpclient相当强大,读写cookie非常容易:

  1. CookieStore cookies=((AbstractHttpClient)client).getCookieStore();//读cookie
  2. ((AbstractHttpClient) client).setCookieStore(cookies);//写cookie
复制代码
另外的一个问题是,为了在各个activity之间使用一个共通的cookie,需要一个全局变量来解决问题。对于java来说,可以使用静态类,但是对于android来说,更符合android结

构的作法是使用拥有这些activity的application类:
首先声明一个application类用来存取cookie:

  1. public class myApp extends Application {
  2.     private CookieStore cookies;   
  3.     public CookieStore getCookie(){    
  4.         return cookies;
  5.     }
  6.     public void setCookie(CookieStore cks){
  7.         cookies = cks;
  8.     }
  9. }
复制代码
另外,要在AndroidManifest.xml文件中将上面声明的这个类绑定到包含所有activity的application上,方法是为application标签加 android:name=".myApp"
这样就可以在Activity中使用这个“全局变量”了:

  1. //设置cookie
  2. myApp appCookie = ((myApp)getApplication());    
  3. appCookie.setCookie(cookies);
  4. //读取cookie
  5. myApp appCookie = ((myApp)getApplicationContext());
  6. cookies = appCookie.getCookie();
复制代码
经过以上的步骤,android程序完成一个Web登录后就可以保持登录的状态了。
ps.
从一个httpclient取得statuscode的方法:

  1. HttpResponse response = client.execute(mypost);
  2. int statuscode = response.getStatusLine().getStatusCode();
复制代码
做的一个是要登录自己的图书馆账号,用于查看自己所借阅的书籍,
看了一下图书馆的代码,发现是POST用户名和密码,
而在代码实现主要有两个难点:一、保存账号密码 二、保存Cookie
那么 ,第一个可以使用之前提到过的Sharedpreference ,每次就直接从sharedpreference里获取账号名和密码就可以了,不需要每次都输入

第二个怎么获得服务器的cookie呢,知道这次的session id
通过Httpclient 中的getcookiestore

  1. List<Cookie> cookies = httpclient.getCookieStore().getCookies();     
  2. if (cookies.isEmpty()) {     
  3. Log.i(TAG, "-------Cookie NONE---------");     
  4. } else {                    
  5. for (int i = 0; i < cookies.size(); i ) {     
  6. //保存cookie      
  7. cookie = cookies.get(i);     
  8. Log.d(TAG, cookies.get(i).getName() "=" cookies.get(i).getValue() );     
  9. }  
复制代码
获得了session id后,怎么再添加到我们的POST或者GET请求里面呢,

  1. HttpPost httpPost = new HttpPost(访问地址);   
  2. httpPost.setHeader("Cookie", "JSESSIONID=" + 我们在静态变量里存放的SessionId);   
  3. HttpResponse httpResponse = httpclient.execute(httpPost);  
  4. HttpGet request = new HttpGet(url+"?"+Params);   
  5.   request.setHeader("Cookie",Sessionid);  
复制代码
转自:http://blog.csdn.net/t80t90s/article/details/7967452

你可能感兴趣的:(android,Web,cookie)