Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> Android 登錄Web 時對cookie 處理

Android 登錄Web 時對cookie 處理

編輯:關於Android編程

對於登錄功能本身沒有任何特別,使用httpclient向服務器post用戶名密碼即可。

但是為了保持登錄的狀態(在各個Activity之間切換時要讓網站知道用戶一直是處於登錄的狀態)就需要進行cookie的讀寫。

httpclient相當強大,讀寫cookie非常容易:

CookieStore cookies=((AbstractHttpClient)client).getCookieStore();//讀cookie
((AbstractHttpClient) client).setCookieStore(cookies);//寫cookie

另外的一個問題是,為了在各個activity之間使用一個共通的cookie,需要一個全局變量來解決問題。對於java來說,可以使用靜態類,但是對於android來說,更符合android結構的作法是使用擁有這些activity的application類:

首先聲明一個application類用來存取cookie:

public class myApp extends Application {


  private CookieStore cookies; 
  public CookieStore getCookie(){  
    return cookies;
  }
  public void setCookie(CookieStore cks){
    cookies = cks;
  }
}

另外,要在AndroidManifest.xml文件中將上面聲明的這個類綁定到包含所有activity的application上,方法是為application標簽加 android:name=".myApp"

這樣就可以在Activity中使用這個“全局變量”了:

//設置cookie
myApp appCookie = ((myApp)getApplication());  
appCookie.setCookie(cookies);
//讀取cookie
myApp appCookie = ((myApp)getApplicationContext());
cookies = appCookie.getCookie();

經過以上的步驟,android程序完成一個Web登錄後就可以保持登錄的狀態了。

ps.

從一個httpclient取得statuscode的方法:

HttpResponse response = client.execute(mypost);
int statuscode = response.getStatusLine().getStatusCode();

做的一個是要登錄自己的圖書館賬號,用於查看自己所借閱的書籍,

看了一下圖書館的代碼,發現是POST用戶名和密碼,

而在代碼實現主要有兩個難點:一、保存賬號密碼 二、保存Cookie

那麼 ,第一個可以使用之前提到過的Sharedpreference ,每次就直接從sharedpreference裡獲取賬號名和密碼就可以了,不需要每次都輸入

第二個怎麼獲得服務器的cookie呢,知道這次的session id

通過Httpclient 中的getcookiestore

List<Cookie> cookies = httpclient.getCookieStore().getCookies();  
if (cookies.isEmpty()) {  
Log.i(TAG, "-------Cookie NONE---------");  
} else {          
for (int i = 0; i < cookies.size(); i ) {  
//保存cookie   
cookie = cookies.get(i);  
Log.d(TAG, cookies.get(i).getName() "=" cookies.get(i).getValue() );  
} 
 

獲得了session id後,怎麼再添加到我們的POST或者GET請求裡面呢,

 
HttpPost httpPost = new HttpPost(訪問地址); 
httpPost.setHeader("Cookie", "JSESSIONID=" + 我們在靜態變量裡存放的SessionId); 
HttpResponse httpResponse = httpclient.execute(httpPost); 
HttpGet request = new HttpGet(url+"?"+Params); 
    request.setHeader("Cookie",Sessionid); 

以上就是對Android 登錄Web 以及登錄保持,對cookie 的管理,有需要的朋友可以參考下。

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved