php okhttp3 上传文件,GitHub - CCC2016/MyOkHttp: 对Okhttp3进行二次封装,对外提供了POST请求、GET请求、PATCH请求、PUT请求、DELETE请求、...

MyOkhttp

68747470733a2f2f696d672e736869656c64732e696f2f62616467652f6c6963656e73652d417061636865253230322d677265656e2e737667

68747470733a2f2f6170692e62696e747261792e636f6d2f7061636b616765732f74616e6773697975616e2f6d6176656e2f6d796f6b687474702f696d616765732f646f776e6c6f61642e737667

对Okhttp3进行二次封装,对外提供了POST请求、GET请求、PATCH请求、PUT请求、DELETE请求、上传文件、下载文件、取消请求、Raw/Json/Gson返回、后台下载管理等功能.

版本更新记录

文章推荐

对于Okhttp3的封装参考了:

如何添加

在app目录下的build.gradle中添加依赖

compile 'com.tsy:myokhttp:1.1.1'

1 总体简介

在项目入口创建唯一MyOkhttp实例

MyOkHttp mMyOkhttp = new MyOkHttp();

也可以自行配置OkhttpClient.

OkHttpClient okHttpClient = new OkHttpClient.Builder()

.connectTimeout(10000L, TimeUnit.MILLISECONDS)

.readTimeout(10000L, TimeUnit.MILLISECONDS)

//其他配置

.build();

MyOkHttp mMyOkhttp = new MyOkHttp(okHttpClient);

1.1 调用方式

整个调用采用链式调用的方式. 方便以后扩展.

1.2 请求类型

现在有Get, Post, Patch, Put, Delete, Upload, Download 这些请求方式

1.3 添加参数方式

添加参数可以使用addParam一个个添加, 也可以使用params一次性添加

1.4 添加Header方式

添加参数可以使用addHeader一个个添加, 也可以使用headers一次性添加

1.5 回调格式

现在回调格式有以下几种:

Raw原生数据 RawResponseHandler

Json JsonResponseHandler

Gson GsonResponseHandler

2 调用示例

2.1 POST请求 + Json回调示例

String url = "http://192.168.2.135/myokhttp/post.php";

Map params = new HashMap<>();

params.put("name", "tsy");

params.put("age", "24");

mMyOkhttp.post()

.url(url)

.params(params)

.tag(this)

.enqueue(new JsonResponseHandler() {

@Override

public void onSuccess(int statusCode, JSONObject response) {

Log.d(TAG, "doPost onSuccess JSONObject:" + response);

}

@Override

public void onSuccess(int statusCode, JSONArray response) {

Log.d(TAG, "doPost onSuccess JSONArray:" + response);

}

@Override

public void onFailure(int statusCode, String error_msg) {

Log.d(TAG, "doPost onFailure:" + error_msg);

}

});

2.2 GET请求 + Raw回调示例

String url = "http://192.168.2.135/myokhttp/get.php";

mMyOkhttp.get()

.url(url)

.addParam("name", "tsy")

.addParam("id", "5")

.tag(this)

.enqueue(new RawResponseHandler() {

@Override

public void onSuccess(int statusCode, String response) {

Log.d(TAG, "doGet onSuccess:" + response);

}

@Override

public void onFailure(int statusCode, String error_msg) {

Log.d(TAG, "doGet onFailure:" + error_msg);

}

});

2.3 Patch请求 + Json回调示例

String url = "http://192.168.2.135/myokhttp/patch.php/id/5/name/tsy";

mMyOkhttp.patch()

.url(url)

.tag(this)

.enqueue(new JsonResponseHandler() {

@Override

public void onSuccess(int statusCode, JSONObject response) {

Log.d(TAG, "doPatch onSuccess:" + response);

}

@Override

public void onFailure(int statusCode, String error_msg) {

Log.d(TAG, "doPatch onFailure:" + error_msg);

}

});

2.4 Put请求 + Json回调示例

String url = "http://192.168.2.135/myokhttp/put.php/id/5/name/tsy/age/15";

mMyOkhttp.put()

.url(url)

.tag(this)

.enqueue(new JsonResponseHandler() {

@Override

public void onSuccess(int statusCode, JSONObject response) {

Log.d(TAG, "doPut onSuccess:" + response);

}

@Override

public void onFailure(int statusCode, String error_msg) {

Log.d(TAG, "doPut onFailure:" + error_msg);

}

});

2.5 Delete请求 + Json回调示例

String url = "http://192.168.2.135/myokhttp/delete.php/id/5";

mMyOkhttp.delete()

.url(url)

.tag(this)

.enqueue(new JsonResponseHandler() {

@Override

public void onSuccess(int statusCode, JSONObject response) {

Log.d(TAG, "doDelete onSuccess:" + response);

}

@Override

public void onFailure(int statusCode, String error_msg) {

Log.d(TAG, "doDelete onFailure:" + error_msg);

}

});

2.6 上传文件 + Gson回调示例

String url = "http://192.168.2.135/myokhttp/upload.php";

mMyOkhttp.upload()

.url(url)

.addParam("name", "tsy")

.addFile("avatar",

new File(Environment.getExternalStorageDirectory()

+ "/ahome/sasas.jpg")) //上传已经存在的File

// .addFile("avatar2", "asdsda.png", byteContents) //直接上传File bytes

.tag(this)

.enqueue(new GsonResponseHandler() {

@Override

public void onFailure(int statusCode, String error_msg) {

Log.d(TAG, "doUpload onFailure:" + error_msg);

}

@Override

public void onProgress(long currentBytes, long totalBytes) {

Log.d(TAG, "doUpload onProgress:" + currentBytes + "/" + totalBytes);

}

@Override

public void onSuccess(int statusCode, UploadModel response) {

Log.d(TAG, "doUpload onSuccess:" + response.ret + " " + response.msg);

}

});

2.7 下载文件

String url = "http://192.168.2.135/myokhttp/head.jpg";

mMyOkhttp.download()

.url(url)

.filePath(Environment.getExternalStorageDirectory() + "/ahome/a.jpg")

.tag(this)

.enqueue(new DownloadResponseHandler() {

@Override

public void onStart(long totalBytes) {

Log.d(TAG, "doDownload onStart");

}

@Override

public void onFinish(File downloadFile) {

Log.d(TAG, "doDownload onFinish:");

}

@Override

public void onProgress(long currentBytes, long totalBytes) {

Log.d(TAG, "doDownload onProgress:" + currentBytes + "/" + totalBytes);

}

@Override

public void onFailure(String error_msg) {

Log.d(TAG, "doDownload onFailure:" + error_msg);

}

});

3 取消请求(建议放在BaseActivity,BaseFragment的onDestroy中)

mMyOkhttp.cancel(this); //tag 即之前请求时传入的tag 建议直接将页面作为object传入

4 下载管理

实现了下载管理的核心逻辑,包括添加下载任务、开始任务、暂停任务、删除任务、任务下载等待、下载进度和状态监听等功能。依赖于MyOkhttp

4.1 实现AbstractDownloadMgr

项目中创建DownloadMgr继承AbstractDownloadMgr,并实现下载任务的状态,进度的本地持久化保存。(AbstractDownloadMgr只负责在内存中存储所有任务,

需要项目自行实现本地持续化存储,重新进入App后的任务恢复等)

示例:

/**

* 实现下载管理 AbstractDownloadMgr

* Created by tsy on 2016/11/24.

*/

public class DownloadMgr extends AbstractDownloadMgr {

private DownloadMgr(Builder builder) {

super(builder);

}

/**

* 初始进入app 恢复所有未完成的任务

*/

@Override

public void resumeTasks() {

if(DEBUG) {

Log.i(TAG, "start resumeTasks");

}

//获取所有未完成的任务(已完成的不需要添加)

DownloadContract.Interactor downloadInteractor = new DownloadInteractor();

ArrayList tasks = downloadInteractor.parseTask(downloadInteractor.getAllUnfinishedDownloadTasks());

//将任务加到下载管理队列中

if(tasks != null && tasks.size() > 0) {

for(int i = 0; i < tasks.size(); i ++) {

Task task = tasks.get(i);

task.setDefaultStatus(DEFAULT_TASK_STATUS_PAUSE); //所有任务初始设置为暂停

addTask(tasks.get(i));

}

downloadInteractor.pauseAllTask();

}

}

/**

* 保存进度

* @param taskId taskId

* @param currentBytes 已经下载的bytes

* @param totalBytes 总共bytes

*/

@Override

protected void saveProgress(String taskId, long currentBytes, long totalBytes) {

DownloadContract.Interactor downloadInteractor = new DownloadInteractor();

downloadInteractor.updateProgress(taskId, currentBytes, totalBytes);

}

/**

* 下载任务开始

* @param taskId task id

*/

@Override

protected void onTaskStart(String taskId) {

DownloadContract.Interactor downloadInteractor = new DownloadInteractor();

downloadInteractor.startTask(taskId);

}

/**

* 下载任务暂停

* @param taskId task id

*/

@Override

protected void onTaskPause(String taskId) {

DownloadContract.Interactor downloadInteractor = new DownloadInteractor();

downloadInteractor.pauseTask(taskId);

}

/**

* 下载任务完成

* @param taskId task id

*/

@Override

protected void onTaskFinish(String taskId) {

DownloadContract.Interactor downloadInteractor = new DownloadInteractor();

downloadInteractor.finishTask(taskId);

}

/**

* 下载任务失败

* @param taskId task id

*/

@Override

protected void onTaskFail(String taskId) {

//失败设置为暂停 允许用户再次尝试开始

DownloadContract.Interactor downloadInteractor = new DownloadInteractor();

downloadInteractor.pauseTask(taskId);

}

//实现Builder

public static class Builder extends AbstractDownloadMgr.Builder {

@Override

public AbstractDownloadMgr build() {

return new DownloadMgr(this);

}

}

}

4.2 使用后台下载管理

4.2.1 项目开始时初始化唯一实例DownloadMgr 并自定义配置

mDownloadMgr = (DownloadMgr) new DownloadMgr.Builder()

.myOkHttp(mMyOkhttp)

.maxDownloadIngNum(5) //设置最大同时下载数量(不设置默认5)

.saveProgressBytes(50 * 1024) //设置每50kb触发一次saveProgress保存进度 (不能在onProgress每次都保存 过于频繁) 不设置默认50kb

.build();

4.2.2 恢复本地存储的所有未完成的任务

mDownloadMgr.resumeTasks();

4.2.3 创建一个下载任务

DownloadMgr.Task task = new DownloadMgr.Task();

task.setTaskId(mDownloadMgr.genTaskId()); //生成一个taskId

task.setUrl("xxxxx"); //下载地址

task.setFilePath("xxxxxxx"); //下载后文件保存位置

task.setCompleteBytes(1234L); //设置已完成的bytes (用于恢复任务时添加,如果新添加的任务不需要设置该字段)

task.setDefaultStatus(DownloadMgr.DEFAULT_TASK_STATUS_START); //任务添加后开始状态 如果不设置 默认任务添加后就自动开始

mDownloadMgr.addTask(task);

4.2.4 开始 暂停任务

mDownloadMgr.startTask("taskId");

mDownloadMgr.pauseTask("taskId");

4.2.5 页面添加下载监听

PS:不要使用匿名类,会造成内存泄露。在onStart或者onResume时初始化监听,在onStop或者onPause时销毁监听

@Override

public void onResume() {

super.onResume();

//每次显示页面的时候加上监听

mDownloadTaskListener = new DownloadTaskListener() {

@Override

public void onStart(String taskId, long completeBytes, long totalBytes) {

//开始下载

}

@Override

public void onProgress(String taskId, long currentBytes, long totalBytes) {

//下载进度

//建议使用handler延迟刷新下载进度 不然过于频繁刷新

if(!mMyHandler.hasMessages(MSG_DELAY_NOTIFICAION)) {

Message message = new Message();

message.what = MSG_DELAY_NOTIFICAION;

mMyHandler.sendMessageDelayed(message, 300);

}

}

@Override

public void onPause(String taskId, long currentBytes, long totalBytes) {

//下载暂停

}

@Override

public void onFinish(String taskId, File file) {

//下载完成

}

@Override

public void onFailure(String taskId, String error_msg) {

//下载失败

}

};

//加入监听

mDownloadMgr.addListener(mDownloadTaskListener);

}

@Override

public void onPause() {

//释放监听 防止内存泄露

mDownloadMgr.removeListener(mDownloadTaskListener);

mDownloadTaskListener = null;

super.onPause();

}

4.3 API

1. 进入应用后恢复所有本地任务

/**

* 初始进入app 恢复所有未完成的任务

*/

void resumeTasks()

2. 添加下载任务

/**

* 添加下载任务

* @param task Task

*/

DownloadTask addTask(Task task)

3. 开始任务

/**

* 开始任务

* @param taskId task id

*/

void startTask(String taskId)

4. 开始所有任务

/**

* 开始所有任务

*/

void startAllTask()

5. 暂停任务

/**

* 暂停任务

* @param taskId task id

*/

void pauseTask(String taskId)

6. 暂停所有任务

/**

* 暂停所有任务

*/

void pauseAllTask()

7. 删除任务

/**

* 删除任务

* @param taskId 任务id

*/

void deleteTask(String taskId)

8. 添加下载监听

/**

* 添加下载监听

* @param downloadTaskListener

*/

void addListener(DownloadTaskListener downloadTaskListener)

9. 移除下载监听

/**

* 移除下载监听

* @param downloadTaskListener

*/

void removeListener(DownloadTaskListener downloadTaskListener)

10. 生成taskId

/**

* 生成taskId yyyyMMddHHmmss+3位随机数字

* @return

*/

String genTaskId()

11. 获取当前任务的下载任务信息

/**

* 获取当前任务的下载任务信息

* @param taskId 任务id

* @return

*/

DownloadTask getDownloadTask(String taskId)

4.4 下载任务状态说明

public class DownloadStatus {

public static final int STATUS_DEFAULT = -1; //初始状态

public static final int STATUS_WAIT = 0; //队列等待中

public static final int STATUS_PAUSE = 1; //暂停

public static final int STATUS_DOWNLOADING = 2; //下载中

public static final int STATUS_FINISH = 3; //下载完成

public static final int STATUS_FAIL = 4; //下载失败

}

4.5 下载任务监听说明

public interface DownloadTaskListener {

/**

* 任务开始

* @param taskId task id

* @param completeBytes 断点续传 已经完成的bytes

* @param totalBytes total bytes

*/

void onStart(String taskId, long completeBytes, long totalBytes);

/**

* 任务下载中

* @param taskId task id

* @param currentBytes 当前已经下载的bytes

* @param totalBytes total bytes

*/

void onProgress(String taskId, long currentBytes, long totalBytes);

/**

* 任务暂停

* @param taskId task id

* @param currentBytes 当前已经下载的bytes

* @param totalBytes total bytes

*/

void onPause(String taskId, long currentBytes, long totalBytes);

/**

* 任务完成

* @param taskId task id

* @param file 下载完成后的file

*/

void onFinish(String taskId, File file);

/**

* 任务失败

* @param taskId task id

* @param error_msg error_msg

*/

void onFailure(String taskId, String error_msg);

}

About Me

微信公众号

License

Copyright 2017 SY.Tang

Licensed under the Apache License, Version 2.0 (the "License");

you may not use this file except in compliance with the License.

You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software

distributed under the License is distributed on an "AS IS" BASIS,

WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

See the License for the specific language governing permissions and

limitations under the License.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值