編輯:關於Android編程
AsyncHttpHelp是一個android平台下基於httpclient開發的HTTP網絡請求工具。
優點
功能
1、普通get請求
2、普通post請求
3、Form表單提交數據
4、二進制數據傳輸
5、json格式內容傳輸(json字符串自動轉java對象,java對象自動轉json字符串)
6、普通文件上傳/下載
7、斷點上傳/下載
8、分塊上傳文件
9、session保持
10、自定義cookie、http頭部信息等
11、取消請求
12、自定義json解析器
13、請求內容,返回內容預處理
14、設置請求結果是否在UI線程執行
測試示例
用法示例
GET請求
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://www.luoxudong.com/") .setCallable(new SimpleRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //請求失敗 } @Override public void onSuccess(String responseInfo) { //請求成功 } }) .build().get();
GET請求(返回結果為JSON,自動轉換成JAVA對象)
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://www.bchun.com/fund/service.do?func=getProvinces") .setResponseClass(Response.class)//返回的json對象類型,自動轉換改類的對象 .setJsonResponseInterceptor(new JsonResponseInterceptor<Response>() {//返回結果攔截器,方便自定義json解析器以及對返回結果作簡單預處理。 @Override public Response convertJsonToObj(String responseStr, Class<Response> mResponseClass) { return new Gson().fromJson(responseStr, mResponseClass); } @Override public boolean checkResponse(Response response) {//可以根據返回的結果判定該請求是否成功,如果返回true,則在callable中調用onSuccess回調方法,為false時調用onFailed回調方法 if (response.getServerResult().getResultCode() == 0){ return true; } setErrorCode(AsyncHttpExceptionCode.defaultExceptionCode.getErrorCode()); setErrorMsg(response.getServerResult().getResultMessage()); return false; } }) .setCallable(new JsonRequestCallable<Response>() {//回調 @Override public void onFailed(int errorCode, String errorMsg) { //請求失敗 } @Override public void onSuccess(Response responseInfo) { //請求成功 } }) .build().get();
POST請求
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://www.bchun.com/fund/service.do?func=getProvinces") .setStrBody("body內容")//post內容 .setCallable(new SimpleRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //請求失敗 } @Override public void onSuccess(String responseInfo) { //請求成功 } }) .build().post();
POST請求(模擬Form表單)
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://www.bchun.com/fund/service.do?func=getProvinces") .addFormData("a", "1")//設置form表單數據,也可以調用setFormDatas方法 .addFormData("b", "luoxudong") .setCallable(new SimpleRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //請求失敗 } @Override public void onSuccess(String responseInfo) { //請求成功 } }) .build().post();
POST請求(內容為二進制數據)
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://www.bchun.com/fund/service.do?func=getProvinces") .setBinaryBody(new byte[]{1,2,3,4,5}) .setCallable(new BinaryRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //請求失敗 } @Override public void onSuccess(byte[] buffer) { //請求成功 } }) .build().post();
POST請求(JSON字符串自動轉換對象)
List<String> list = new ArrayList<String>(); list.add("item1"); list.add("item2"); Request req = new Request(); req.setKey1("value1"); req.setKey2(1); req.setKey3(true); req.setKey4(list); AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://www.bchun.com/fund/service.do?func=getProvinces") .setRequestObj(req)//json格式請求內容 .setJsonRequestInterceptor(new JsonRequestInterceptor() {//請求數據攔截器,自定義json解析器 @Override public String convertJsonToObj(Object requestObj) { return new Gson().toJson(requestObj); } }) .setResponseClass(Response.class) .setJsonResponseInterceptor(new JsonResponseInterceptor<Response>() {//返回結果攔截器,方便自定義json解析器以及對返回結果作簡單預處理。 @Override public Response convertJsonToObj(String responseStr, Class<Response> mResponseClass) { return new Gson().fromJson(responseStr, mResponseClass); } @Override public boolean checkResponse(Response response) { if (response.getServerResult().getResultCode() == 0){ return true; } setErrorCode(AsyncHttpExceptionCode.defaultExceptionCode.getErrorCode()); setErrorMsg(response.getServerResult().getResultMessage()); return false; } }) .setCallable(new JsonRequestCallable<Response>() { @Override public void onFailed(int errorCode, String errorMsg) { //請求失敗 } @Override public void onSuccess(Response responseInfo) { //請求成功 } }) .build().post();
普通下載
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://shouji.360tpcdn.com/151125/1259d7ddba8a048c2b9e778c9b5a9d04/com.bchun.fundqa_5.apk") .setDownloadFileDir("/sdcard")//文件本地保存路徑 .setDownloadfileName("fund.apk")//文件名稱 .setCallable(new DownloadRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //下載失敗 } @Override public void onTransfering(long totalLength, long transferedLength) { //下載進度 } @Override public void onSuccess(String responseInfo) { //下載完成 } }) .build().download();
斷點下載
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://shouji.360tpcdn.com/151125/1259d7ddba8a048c2b9e778c9b5a9d04/com.bchun.fundqa_5.apk") .setDownloadFileDir("/sdcard")//文件本地保存路徑 .setDownloadfileName("fund.apk.temp")//文件名稱 .setFileStartPos(1000)//設置續下載開始位置 .setCallable(new DownloadRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //下載失敗 } @Override public void onTransfering(long totalLength, long transferedLength) { //下載進度 } @Override public void onSuccess(String responseInfo) { //下載完成 } }) .build().download();
普通上傳
AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://192.168.100.62:8080/MyHost/fund/upload.do") .addUploadFile("file", new File("/sdcard/Fund.apk"))//添加文件,也可以調用setFileWrappers方法,同時添加多個文件 .addUploadFile("file1", new File("/sdcard/wifi_config.log")) .addFormData("md5", "aadfsdf")//添加form參數 .setCallable(new UploadRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //上傳失敗 } @Override public void onTransfering(String name, long totalLength, long transferedLength) { //上傳進度 } @Override public void onTransferSuc(String name) { //文件name上傳完成 } @Override public void onSuccess(String responseInfo) { //全部上傳成功! } @Override public void onCancel() { //上傳取消 } }) .build().upload();
斷點上傳
FileWrapper fileWrapper = new FileWrapper(); fileWrapper.setFile(new File("/sdcard/Fund.apk")); fileWrapper.setBlockSize(100000);//上傳100000字節數據,默認為0,上傳至文件末尾 fileWrapper.setStartPos(1000);//從1000字節開始上傳 AsyncHttpRequest request = new AsyncHttpUtil.Builder() .url("http://192.168.100.62:8080/MyHost/fund/upload.do") .addFileWrapper("file", fileWrapper)//自定義上傳文件,支持斷點續傳,支持上傳指定數據大小 .addFormData("md5", "aadfsdf")//添加form參數 .setCallable(new UploadRequestCallable() { @Override public void onFailed(int errorCode, String errorMsg) { //上傳失敗 } @Override public void onTransfering(String name, long totalLength, long transferedLength) { //上傳進度 } @Override public void onTransferSuc(String name) { //文件name上傳完成 } @Override public void onSuccess(String responseInfo) { //上傳成功! } @Override public void onCancel() { //上傳取消 } }) .build().upload();
中斷請求
request.cancel();
打開/關閉日志輸出
AsyncHttpLog.enableLog(); AsyncHttpLog.disableLog();
以上就是本文的全部內容,希望對大家的學習有所幫助。
前言以前的導航頁總是使用viewPager配套fragment來實現的,某天一個妹子說其實導航頁也可以使用ViewFilpper 來實現,哈哈確實不錯,前段時間就用Vie
導入工程到Android Studio時,gradle出現如下錯誤。Error:Failed to complete Gradle execution.Cause:Una
ContentProvider,從字面意義上理解,內容提供者,這個類目的就是一個橋梁的作用,讓一個應用的數據(SQLiteDatabase, SharedPreferen
在Android開發中,事件分發機制是一塊Android比較重要的知識體系,了解並熟悉整套的分發機制有助於更好的分析各種點擊滑動失效問題,更好去擴展控件的事件功能和開發自