Android用戶端實現註冊、登入詳解(1)_Android

來源:互聯網
上載者:User

我們在開發安卓App時難免要與伺服器打交道,尤其是對於使用者帳號資訊的註冊與登入更是每個Android開發人員必須掌握的技能,本文將對用戶端的註冊/登入功能的實現進行分析,不到之處還請指出。

在這裡我們僅討論用戶端如何請求伺服器進行註冊,而伺服器在收到用戶端請求後進行的一系列操作並不在本文所述範圍內,有興趣大家可以參考 

請求伺服器 

用戶端在進行使用者資訊的註冊和登入時一般使用post請求(攜帶參數)去伺服器。以volley架構請求伺服器為例,真正與伺服器進行互動的就是如下代碼:

StringRequest request=new StringRequest(Method.POST, url, new Listener<String>() { //請求成功 @Override public void onResponse(String s) { //執行請求成功的回調 callback.onSuccess() } }, new ErrorListener() { //請求錯誤 @Override public void onErrorResponse(VolleyError volleyError) { //執行請求失敗的回調 callback.onFailure() } }){ //攜帶參數(Map集合) @Override protected Map<String, String> getParams() throws AuthFailureError { return parames; } }; //將請求添加到請求隊列中 Volley.newRequestQueue(context).add(request);

 當然,我們在請求伺服器成功或失敗時應該設定相應的回調方法,讓我們能夠進行一些操作。
 •callback.onSuccess() //請求成功的回調
 1.儲存使用者註冊資訊(SP中和Application中)
 2.跳轉到首頁面 

•callback.onFailure() //請求失敗的回調

 1.提示錯誤資訊 

下面通過一個具體的demo來介紹
(聲明:此demo為阿福老師IT藍豹App的代碼截取) 

註:我們在與伺服器進行互動時,必須按照規定的介面和規則進行請求,這裡使用的是IT藍豹App中的伺服器,伺服器的註冊介面資料格式如下

 1.url:http://www.itlanbao.com/api/app/users/user_register_Handler.ashx

2.參數說明
    nickname       必須有    暱稱
    email          必須有    郵箱
    password       必須有    密碼
    accesstoken    必須有    簽名md5(nickname+email+password+"雙方平台約定公開金鑰")

3.請求方式:POST

4.傳回值格式:

 成功 { "ret":0, "errcode":0, "msg":"介面調用成功", "data":{ "userid":"16489", "email":"nnn@aaa.com", "nickname":"duss", "userhead":"http://img.itlanbao.com/avatar.png" }  } 失敗 { "ret":1, "errcode":1, "msg":"介面調用失敗" }

demo示範

 

主要實現代碼(demo會在文章最後給出) 

1.註冊頁面中(RegisterActivity),點擊註冊按鈕

 registBtn.setOnClickListener(new Button.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub //獲得使用者輸入的資訊 String nick = loginNick.getText().toString(); String emailStr = email.getText().toString(); String passwordStr = password.getText().toString(); if (!TextUtils.isEmpty(nick) &&  !TextUtils.isEmpty(emailStr)  && !TextUtils.isEmpty(passwordStr)) { if (Utils.isEmail(emailStr)) {//驗證郵箱格式是否符合  //調用RequestApiData中的getRegistData()方法進行註冊,傳入使用者輸入的暱稱,郵箱、密碼,以及解析資料的bean對象和callback對象(回調到自身)  RequestApiData.getInstance().getRegistData(nick, emailStr, passwordStr,  AnalyticalRegistInfo.class, RegisterActivity.this); } else {  Toast.makeText(RegisterActivity.this, "輸入郵箱有誤", Toast.LENGTH_SHORT).show(); } } else { Toast.makeText(RegisterActivity.this, "輸入資訊未完全", Toast.LENGTH_SHORT).show(); } } });

注意:這個註冊的方法中,我們傳入的最後一個參數是回調的對象,這裡我們傳入的是RegisterActivity自身,所以它需要實現

HttpResponeCallBack介面 RequestApiData.getInstance().getRegistData(nick, emailStr, passwordStr,  AnalyticalRegistInfo.class, RegisterActivity.this);
 

2.請求伺服器的回調介面(HttpResponeCallBack)

 public interface HttpResponeCallBack { public void onResponeStart(String apiName); /** * 此回調只有調用download方法下載資料時才生效 *  * @param apiName * @param count * @param current */ public void onLoading(String apiName, long count, long current); public void onSuccess(String apiName, Object object); public void onFailure(String apiName, Throwable t, int errorNo, String strMsg);}

 3.網路介面類(RequestApiData)

 public class RequestApiData { private static RequestApiData instance = null; private HttpResponeCallBack mCallBack = null; //建立介面對象 public static RequestApiData getInstance() { if (instance == null) { instance = new RequestApiData(); } return instance; } /** * 4.6註冊使用者介面 * @param nickname 暱稱 * @param email 郵箱 * @param password 密碼 * @param clazz 資料返回的解析對象 * @param callback 回調 * 特別要注意參數位置不能變要根據文檔來 * 請求方式:POST */ public void getRegistData(String nickname,String email ,String password, Class<AnalyticalRegistInfo> clazz, HttpResponeCallBack callback) { mCallBack = callback; //這是每一個介面的唯一標示 String tagUrl = UrlConstance.KEY_REGIST_INFO;//註冊介面 //將註冊的資訊儲存在map中(須和伺服器端一致) HashMap<String, String> parameter = new HashMap<String, String>(); parameter.put("nickname", nickname); parameter.put("email",email); parameter.put("password",password); //拼接參數資訊,暱稱,郵箱,密碼,公開金鑰,並用md5進行加密 StringBuilder builder = new StringBuilder(); builder.append(nickname); builder.append(email); builder.append(password); builder.append(UrlConstance.PUBLIC_KEY); parameter.put(UrlConstance.ACCESSTOKEN_KEY,MD5Util.getMD5Str(builder.toString())); //調用RequestManager的post方法,請求伺服器 RequestManager.post(UrlConstance.APP_URL,tagUrl, parameter, clazz, callback); }}

 4.網路請求處理的類(RequestManager)

 public class RequestManager { private static RequestQueue mRequestQueue; private static ImageLoader mImageLoader; private synchronized static void initRequestQueue() { if (mRequestQueue == null) { //建立一個請求隊列(使用Volley架構) mRequestQueue = Volley.newRequestQueue(ItLanbaoLibApplication.getInstance()); } } /** * 添加請求到請求隊列中 * @param request * @param tag */ private static void addRequest(Request<?> request, Object tag) { if (tag != null) { request.setTag(tag); } mRequestQueue.add(request); } /** * post 請求資料 * * @param app_url 公用的介面首碼 http://www.itlanbao.com/api/app/ * @param tag_url 介面名稱,eg:users/user_register_Handler.ashx(註冊介面) * @param parameter 請求參數封裝對象 * @param clazz 返回資料封裝對象,如果傳null,則直接返回String * @param callback 介面回調監聽 */ public static <T> void post(final String app_url, final String tag_url, final HashMap<String, String> parameter, Class<T> clazz,  final HttpResponeCallBack callback) { //發送post請求伺服器 post(app_url, tag_url, parameter, clazz, callback, Priority.NORMAL); } /** * post 請求資料 * * @param app_url 路徑 * @param url 介面名稱 * @param parameter 請求參數封裝對象 * @param clazz 返回資料封裝對象,如果傳null,則直接返回String * @param callback 介面回調監聽 * @param priority 指定介面請求線程優先順序 */ public static <T> void post(final String app_url, final String url, final HashMap<String, String> parameter, final Class<T> clazz,  final HttpResponeCallBack callback, Priority priority) { if (callback != null) { callback.onResponeStart(url);//回調請求開始 } //初始化請求隊列 initRequestQueue(); //將公用的介面首碼和介面名稱拼接 //eg:拼接成註冊的介面 http://www.itlanbao.com/api/app/users/user_register_Handler.ashx StringBuilder builder = new StringBuilder(app_url); builder.append(url); {// 檢查當前網路是否可用 final NetworkUtils networkUtils = new NetworkUtils(ItLanbaoLibApplication.getInstance()); if (!networkUtils.isNetworkConnected() && android.os.Build.VERSION.SDK_INT > 10) { if (callback != null) {  callback.onFailure(url, null, 0, "網路出錯");//回調請求失敗  return; } } } /** * 使用Volley架構真正去請求伺服器 * Method.POST:請求方式為post * builder.toString():請求的連結 * Listener<String>:監聽 */ StringRequest request = new StringRequest(Method.POST, builder.toString(), new Listener<String>() {  @Override  public void onResponse(String response) {  // TODO Auto-generated method stub  try {  if (response != null && callback != null) {  Gson gson = new Gson();  //回調請求成功,傳入url和解析的對象  callback.onSuccess(url, gson.fromJson(response, clazz));  }  } catch (Exception e) {  // TODO: handle exception  if (callback != null) {  //回調請求失敗--解析異常  callback.onFailure(url, e, 0, "解析異常");  return;  }  }  } }, new ErrorListener() { //請求出錯的監聽 @Override public void onErrorResponse(VolleyError error) { if (callback != null) {  if (error != null) {  callback.onFailure(url, error.getCause(), 0,  error.getMessage());  } else {  callback.onFailure(url, null, 0, "");  } } } }) { //post請求的參數資訊 protected Map<String, String> getParams() { return getPostApiParmes(parameter); } }; //添加請求到請求隊列中 addRequest(request, url); } /* * post參數 *  * ts:時間戳記 sign: 介面簽名 parms = 按文檔參數拼接 parm[0]+ … + parm[n-1] sign = * md5(parms+"雙方平台約定公開金鑰") */ private static ApiParams getPostApiParmes(final HashMap<String, String> parameter) { ApiParams api = new ApiParams(); for (Entry<String, String> entry : parameter.entrySet()) { api.with(entry.getKey(), entry.getValue()); } return api; }}

 5.在請求伺服器成功/失敗後會執行回調方法,而我們傳入的callback對象是自身(RegisterActivity),所以現在我們回到註冊頁面

 @Override public void onResponeStart(String apiName) { // TODO Auto-generated method stub Toast.makeText(RegisterActivity.this, "正在請求資料...", Toast.LENGTH_SHORT).show(); } @Override public void onLoading(String apiName, long count, long current) { Toast.makeText(RegisterActivity.this, "Loading...", Toast.LENGTH_SHORT).show();  } @Override public void onSuccess(String apiName, Object object) { // TODO Auto-generated method stub //註冊介面 if (UrlConstance.KEY_REGIST_INFO.equals(apiName)) { if (object != null && object instanceof AnalyticalRegistInfo) { AnalyticalRegistInfo info = (AnalyticalRegistInfo) object; String successCode = info.getRet(); //請求成功 if (successCode.equals(Constant.KEY_SUCCESS)) {  UserBaseInfo baseUser = new UserBaseInfo();  baseUser.setEmail(info.getEmail());  baseUser.setNickname(info.getNickname());  baseUser.setUserhead(info.getUserhead());  baseUser.setUserid(String.valueOf(info.getUserid()));  ItLanBaoApplication.getInstance().setBaseUser(baseUser);  UserPreference.save(KeyConstance.IS_USER_ID, String.valueOf(info.getUserid()));  UserPreference.save(KeyConstance.IS_USER_ACCOUNT, info.getEmail());  UserPreference.save(KeyConstance.IS_USER_PASSWORD, password.getText().toString());  Intent intent = new Intent(RegisterActivity.this, MainActivity.class);  RegisterActivity.this.startActivity(intent);  Toast.makeText(RegisterActivity.this, "註冊成功...", Toast.LENGTH_SHORT).show();  RegisterActivity.this.finish(); } else {  Toast.makeText(RegisterActivity.this, "註冊失敗", Toast.LENGTH_SHORT).show(); } } } } @Override public void onFailure(String apiName, Throwable t, int errorNo, String strMsg) { Toast.makeText(RegisterActivity.this, "Failure", Toast.LENGTH_SHORT).show(); } 

demo下載地址:http://xiazai.jb51.net/201611/yuanma/Androidlogindemo(jb51.net).rar

至此,安卓用戶端的註冊功能就實現了,下一篇中將會介紹登入和自動登入的實現,盡請關注。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.