android登錄Web以及登錄保持,cookie管理相關
但是為了保持登錄的狀態(在各個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);