android登錄Web以及登錄保持,cookie管理相關

對於登錄功能本身沒有任何特別,使用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); 
 

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。