您好,登錄后才能下訂單哦!
小編給大家分享一下如何利用okhttp框架實現(xiàn)包含驗證碼的用戶登錄并保持session操作,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
一、 這篇文章要解決什么問題,能學(xué)習(xí)到什么?
最近要做一個院務(wù)系統(tǒng)的項目,會把我的學(xué)習(xí)新知識的過程記錄下來,本篇文章是實現(xiàn)登錄的操作,本來以為登錄的過程是一件比較簡單的事情,但是深入了解過后還是有一定難度:
1. 在登錄過程中要獲取驗證碼照片,利用http的get操作后,要穿參數(shù)過去服務(wù)器,就要用post。
2. 上述的get和post操作用很多現(xiàn)在網(wǎng)絡(luò)的框架都能實現(xiàn),比如volley,但是在獲取驗證碼照片后是要進行一個session的保持的,所以在查閱資料后利用okhttp框架來構(gòu)建這個項目比較方便快捷。
二、問:什么是session和cookie?
簡單來說,cookie就是客戶端的會話id,而session就是服務(wù)器端的會話id,根據(jù)這個id號可以查詢到你的會話內(nèi)容。
(想要了解更多cookie和session的知識可以點擊這里)
http://blog.csdn.net/androidxiaogang/article/details/51925388
在本項目中用到的是驗證碼照片的獲取,因為每次刷新驗證碼的url都會有不同的驗證碼照片出現(xiàn),所以需要保存驗證碼的session,不然別人怎么知道你和哪個驗證碼進行了“會話”。先上照片:
如圖分為四個步驟,結(jié)合文字更容易理解:
1. 客戶端發(fā)個請求驗證碼照片的請求,帶回來了照片和一個jsessionid的字段存在用戶的cookie中。
2. 我們從cookie頭中取出這個session,然后打包參數(shù)發(fā)過去的時候順便帶上這個session,讓服務(wù)器這個家伙知道是誰發(fā)的。
四個步驟兩點總結(jié),在加上代碼就更好理解了。
三、分析部分重要代碼 ***再貼上全部代碼
看一下后臺那邊給我們的數(shù)據(jù)有什么,有url_randCodeImage用來發(fā)送get請求獲取照片,還有url_login用來post數(shù)據(jù)過去,這些就是我們要打包發(fā)送過去的數(shù)據(jù):
還有我們的xml界面
首先是我們的驗證碼照片的獲取與異步加載圖片
//發(fā)送請求獲取驗證碼照片 private void ChangeImage() { Request request = new Request.Builder() .url(App.url_randCodeImage) .build(); Call call = okHttpClient.newCall(request); call.enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { Log.i("info_callFailure",e.toString()); } @Override public void onResponse(Call call, Response response) throws IOException { byte[] byte_image = response.body().bytes(); //通過handler更新UI Message message = handler.obtainMessage(); message.obj = byte_image; message.what = SUCCESS; Log.i("info_handler","handler"); handler.sendMessage(message); //獲取session的操作,session放在cookie頭,且取出后含有“;”,取出后為下面的 s (也就是jsesseionid) Headers headers = response.headers(); Log.d("info_headers", "header " + headers); List<String> cookies = headers.values("Set-Cookie"); String session = cookies.get(0); Log.d("info_cookies", "onResponse-size: " + cookies); s = session.substring(0, session.indexOf(";")); Log.i("info_s", "session is :" + s); } }); } //異步加載圖片 public Handler handler = new Handler(){ @Override public void handleMessage(Message msg) { switch (msg.what){ //加載網(wǎng)絡(luò)成功進行UI的更新,處理得到的圖片資源 case SUCCESS: //通過message,拿到字節(jié)數(shù)組 byte[] Picture = (byte[]) msg.obj; //使用BitmapFactory工廠,把字節(jié)數(shù)組轉(zhuǎn)化為bitmap Bitmap bitmap = BitmapFactory.decodeByteArray(Picture, 0, Picture.length); //通過imageview,設(shè)置圖片 img_identy.setImageBitmap(bitmap); break; //當(dāng)加載網(wǎng)絡(luò)失敗執(zhí)行的邏輯代碼 case FALL: Toast.makeText(MainActivity.this, "網(wǎng)絡(luò)出現(xiàn)了問題", Toast.LENGTH_SHORT).show(); break; } } };
獲取了照片和session之后,我們就打包發(fā)送數(shù)據(jù)過去:
private void LoginServer() { Log.i("info_Login","知道了session:"+s); OkHttpClient client = new OkHttpClient(); FormBody body = new FormBody.Builder() .add("userName",et_username.getText().toString()) .add("password",et_code.getText().toString()) .add("randCode",et_identy.getText().toString()) .add("langCode","zh-cn") .build(); Request request = new Request.Builder() .addHeader("cookie",s) .url(App.url_login) .post(body) .build(); Call call2 = okHttpClient.newCall(request); call2.enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { Log.i("info_call2fail",e.toString()); } @Override public void onResponse(Call call, Response response) throws IOException { if(response.isSuccessful()){ Log.i("info_call2success",response.body().string()); } Headers headers = response.headers(); Log.i("info_respons.headers",headers+""); } }); }
***來看看我們成功登錄后log出來的信息
以上是“如何利用okhttp框架實現(xiàn)包含驗證碼的用戶登錄并保持session操作”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。