NoHttp封裝--01

来源:https://www.cnblogs.com/ganchuanpu/archive/2018/05/12/9029159.html
-Advertisement-
Play Games

NoHttpActivity CallServer: ResponseListener: HttpCallBack FastJsonRequest:自定義FastJsonRequest對象,所有的自定義對象都要繼承{@link RestReqeust} WaitDialog: Constants ...


NoHttpActivity

 1 public class NoHttpActivity extends Activity implements View.OnClickListener {
 2 
 3     private final int NOHTTP_LOGIN = 0x01;//登陸
 4     private final int NOHTTP_LOGOUT = 0x02;//退出
 5 
 6     private TextView tvResult;
 7 
 8     @Override
 9     protected void onCreate(Bundle savedInstanceState) {
10         super.onCreate(savedInstanceState);
11         setContentView(R.layout.activity_nohttp);
12         findViewById(R.id.btn_login).setOnClickListener(this);
13         findViewById(R.id.btn_logout).setOnClickListener(this);
14         tvResult = (TextView) findViewById(R.id.tv_result);
15     }
16 
17     @Override
18     public void onClick(View v) {
19         if (v.getId() == R.id.btn_login) {
20             FastJsonRequest request = new FastJsonRequest(Constants.LOGIN, RequestMethod.GET);
21             request.add("userName", "yolanda");
22             request.add("userPwd", "123");
23             CallServer.getInstance().add(this, request, callBack, NOHTTP_LOGIN, true, false, true);
24         } else {
25             FastJsonRequest request = new FastJsonRequest(Constants.LOGOUT, RequestMethod.GET);
26             CallServer.getInstance().add(this, request, callBack, NOHTTP_LOGOUT, true, false, true);
27         }
28     }
29 
30     private HttpCallBack<JSONObject> callBack = new HttpCallBack<JSONObject>() {
31 
32         @Override
33         public void onSucceed(int what, Response<JSONObject> response) {
34             if (what == NOHTTP_LOGIN) {// 處理登錄結果
35                 JSONObject jsonObject = response.get();
36                 tvResult.setText("登錄介面數據:" + jsonObject.getString("data"));
37             } else if (what == NOHTTP_LOGOUT) {// 處理登出結果
38                 JSONObject jsonObject = response.get();
39                 tvResult.setText("退出介面數據:" + jsonObject.getString("data"));
40             }
41         }
42 
43         @Override
44         public void onFailed(int what, String url, Object tag, Exception exception, int responseCode, long networkMillis) {
45             tvResult.setText("請求失敗");
46         }
47     };
48 
49 }

CallServer:

 1 public class CallServer {
 2 
 3     private static CallServer instance;
 4 
 5     private RequestQueue queue;
 6 
 7     public synchronized static CallServer getInstance() {
 8         if (instance == null) {
 9             instance = new CallServer();
10         }
11         return instance;
12     }
13 
14     private CallServer() {
15         queue = NoHttp.newRequestQueue();
16     }
17 
18     /**
19      * 添加一個請求到請求隊列
20      * 
21      * @param context 上下文
22      * @param request 請求對象
23      * @param callBack 接受回調結果
24      * @param what what,當多個請求用同一個responseListener接受結果時,用來區分請求
25      * @param isShowDialog 是否顯示dialog
26      * @param isCanCancel 請求是否能被用戶取消
27      * @param isShowError 是否提示用戶錯誤信息
28      */
29     public <T> void add(Context context, Request<T> request, HttpCallBack<T> callBack, int what, boolean isShowDialog, boolean isCanCancel, boolean isShowError) {
30         queue.add(what, request, new ResponseListener<T>(request, context, callBack, isShowDialog, isCanCancel, isShowError));
31     }
32 
33 }

ResponseListener:

 1 public class ResponseListener<T> implements OnResponseListener<T> {
 2 
 3     private Request<T> mRequest;
 4 
 5     private WaitDialog mDialog;
 6 
 7     private HttpCallBack<T> callBack;
 8 
 9     private boolean isShowError;
10 
11     public ResponseListener(Request<T> request, Context context, HttpCallBack<T> callBack, boolean isShowDialog, boolean isCanCancel, boolean isShowError) {
12         this.mRequest = request;
13         this.callBack = callBack;
14         this.isShowError = isShowError;
15         if (context != null && isShowDialog) {
16             mDialog = new WaitDialog(context);
17             mDialog.setCancelable(isCanCancel);
18             mDialog.setOnCancelListener(new DialogInterface.OnCancelListener() {
19                 @Override
20                 public void onCancel(DialogInterface dialog) {
21                     mRequest.cancel(true);
22                 }
23             });
24         }
25     }
26 
27     @Override
28     public void onStart(int what) {
29         if (mDialog != null && !mDialog.isShowing())
30             mDialog.show();
31     }
32 
33     @Override
34     public void onSucceed(int what, Response<T> response) {
35         if (callBack != null)
36             callBack.onSucceed(what, response);
37     }
38 
39     @Override
40     public void onFailed(int what, String url, Object tag, Exception exception, int responseCode, long networkMillis) {
41         if (isShowError) {
42             if (exception instanceof ClientError) {// 客戶端錯誤
43                 Toast.show("客戶端發生錯誤");
44             } else if (exception instanceof ServerError) {// 伺服器錯誤
45                 Toast.show("伺服器發生錯誤");
46             } else if (exception instanceof NetworkError) {// 網路不好
47                 Toast.show("請檢查網路");
48             } else if (exception instanceof TimeoutError) {// 請求超時
49                 Toast.show("請求超時,網路不好或者伺服器不穩定");
50             } else if (exception instanceof UnKnownHostError) {// 找不到伺服器
51                 Toast.show("未發現指定伺服器");
52             } else if (exception instanceof URLError) {// URL是錯的
53                 Toast.show("URL錯誤");
54             } else if (exception instanceof NotFoundCacheError) {
55                 Toast.show("沒有發現緩存");
56             } else {
57                 Toast.show("未知錯誤");
58             }
59         }
60         if (callBack != null)
61             callBack.onFailed(what, url, tag, exception, responseCode, networkMillis);
62     }
63 
64     @Override
65     public void onFinish(int what) {
66         if (mDialog != null && mDialog.isShowing())
67             mDialog.dismiss();
68     }
69 
70 }

HttpCallBack

 1 public interface HttpCallBack<T> {
 2 
 3     /**
 4      * Server correct response to callback when an HTTP request.
 5      *
 6      * @param what the credit of the incoming request is used to distinguish between multiple requests.
 7      * @param response in response to the results.
 8      */
 9     void onSucceed(int what, Response<T> response);
10 
11     /**
12      * When there was an error correction.
13      *
14      * @param what the credit of the incoming request is used to distinguish between multiple requests.
15      * @param url url.
16      * @param tag tag of request callback.
17      * @param exception error message for request.
18      * @param responseCode server response code.
19      * @param networkMillis request process consumption time.
20      */
21     void onFailed(int what, String url, Object tag, Exception exception, int responseCode, long networkMillis);
22 
23 }

FastJsonRequest:自定義FastJsonRequest對象,所有的自定義對象都要繼承{@link RestReqeust}

 1 public class FastJsonRequest extends RestRequest<JSONObject> {
 2 
 3     public FastJsonRequest(String url, RequestMethod requestMethod) {
 4         super(url, requestMethod);
 5     }
 6 
 7     public FastJsonRequest(String url) {
 8         super(url);
 9     }
10 
11     /**
12      * 高速服務端你能接受的數據類型是什麼
13      */
14     @Override
15     public String getAccept() {
16         return JsonObjectRequest.ACCEPT;
17     }
18 
19     /**
20      * @param url 請求的url
21      * @param responseHeaders 服務端的響應頭
22      * @param 服務端的響應數據
23      * @return 你解析後的對象
24      */
25     @Override
26     public JSONObject parseResponse(String url, Headers responseHeaders, byte[] responseBody) {
27         return parse(url, responseHeaders, responseBody);
28     }
29 
30     /**
31      * 解析服務端數據成{@link JsonObject}
32      * 
33      * @param url
34      * @param responseHeaders
35      * @param responseBody
36      * @return
37      */
38     public static JSONObject parse(String url, Headers responseHeaders, byte[] responseBody) {
39         String string = StringRequest.parseResponseString(url, responseHeaders, responseBody);
40         JSONObject jsonObject = null;
41         try {
42             jsonObject = JSON.parseObject(string);
43         } catch (Exception e) {// 可能返回的數據不是json,或者其他異常
44             string = "{}";
45             jsonObject = JSON.parseObject(string);
46         }
47         return jsonObject;
48     }
49 
50 }

WaitDialog:

 1 public class WaitDialog extends ProgressDialog {
 2 
 3     public WaitDialog(Context context) {
 4         super(context);
 5         requestWindowFeature(Window.FEATURE_NO_TITLE);
 6         setCanceledOnTouchOutside(false);
 7         setProgressStyle(STYLE_SPINNER);
 8         setMessage("正在請求,請稍候…");
 9     }
10 
11 }

 Constants

public class Constants {

    private static final String SERVER = "http://192.168.1.116/HttpServer/";

    /**
     * 登錄介面
     */
    public static final String LOGIN = SERVER + "login";
    
    /**
     * 退出登錄介面
     */
    public static final String LOGOUT = SERVER + "logout";

}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 背景 當站點的規模不斷膨脹,這給資料庫帶來巨大的查詢壓力,單單資料庫性能優化已經是不夠的,需對資料庫進行伸縮擴展。有三種方式: 1、資料庫主從 2、數據表分庫(垂直分區) 3、數據分區(水平分區) PS:事實上,很多大規模的站點基本上經歷了從簡單主從複製到垂直分區,再到水平分區的步驟。 資料庫主從 ...
  • 將數據導入 oracle 的方法應該很多 , 對於不同需求有不同的導入方式 , 最近使用oracle的sqlldr命令 導入資料庫數據感覺是個挺不錯的技術點 。 使用sqlldr命令 將文本文件導入 oracle中大致需要兩步 : 第一步:編寫ctl控制文件 Load data --裝載數據(第二步 ...
  • 最的mysql在裝的時候就可以設置 ,但是低版本的好像不行,需要在裝了以後才能設置。 mac下,mysql5.7.18連接出錯,錯誤信息為:Access denied for user 'root'@'localhost' (using password: YES) ()裡面的為shell中輸入的命 ...
  • 在ubuntu系統中操作命令:登錄:mysql -uroot -p啟動:service mysql start停止:service mysql stop重啟:service mysql restart 創建資料庫:create database 資料庫名字 charset = utf8;刪除資料庫: ...
  • 1、Default模式,也是沒有設置緩存模式時的預設模式 這個模式實現http協議中的內容,比如響應碼是304時,當然還會結合E-Tag和LastModify等頭。 StringRequest request = new StringRequest(url, method); request.set ...
  • NoHttp請求自動維持Cookie: 1.支持Session、Cookie、臨時Cookie的位置。 2.支持App重啟、關機開機後繼續持久化維持。 3.提供了介面,允許開發者監聽Cookie的變化,也可以改變某個Cookie的值。 伺服器端: 客戶端: 文章:https://blog.csdn. ...
  • 原文 http://blog.votzone.com/2018/05/12/apk-merge.html 之前接手過一個sdk的開發工作,在開發過程中有一個很重要的點就是儘量使用代碼來創建控制項,資源文件最好放到assets目錄下,如果必須使用res資源,需要通過 getResources().get ...
  • bean實體類請求: 1.bean 2.針對bean的request 3.具體在activity中使用: 可以解析所有JavaBean的自定義請求 activity ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...