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

jopen 12年前發布 | 65K 次閱讀 Android 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); 

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!