diff --git a/DEV_LOG.md b/DEV_LOG.md index c452717a..cc252064 100644 --- a/DEV_LOG.md +++ b/DEV_LOG.md @@ -5,6 +5,7 @@ - 修复同一个url地址的任务提示路径冲突的问题 - 修复m3u8任务地址错误时,无法删除实体的问题 https://github.com/AriaLyy/Aria/issues/712 - 修复m3u8gzip的问题,https://github.com/AriaLyy/Aria/issues/639 + - 修复http表单上传,本地md5和上传的服务的的文件md5不一致的问题 https://github.com/AriaLyy/Aria/issues/730 - 增加m3u8密钥下载地址转换器增加ts列表的url地址 https://github.com/AriaLyy/Aria/issues/718 - 增加现在http文件下载将使用HEAD请求获取文件大小,配置文件增加 - 增加允许不使用apt直接通过实现监听器来回调下载进度更新,该功能由[chenfei0928](https://github.com/chenfei0928)提交,感谢他的pr。如果注解不生效,只需要实现`DownloadListener`接口便可 diff --git a/HttpComponent/src/main/java/com/arialyy/aria/http/upload/HttpUThreadTaskAdapter.java b/HttpComponent/src/main/java/com/arialyy/aria/http/upload/HttpUThreadTaskAdapter.java index 4b496236..5c69904d 100644 --- a/HttpComponent/src/main/java/com/arialyy/aria/http/upload/HttpUThreadTaskAdapter.java +++ b/HttpComponent/src/main/java/com/arialyy/aria/http/upload/HttpUThreadTaskAdapter.java @@ -26,6 +26,7 @@ import com.arialyy.aria.util.CommonUtil; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; +import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStream; @@ -75,7 +76,6 @@ final class HttpUThreadTaskAdapter extends BaseHttpThreadTaskAdapter { mHttpConn.setRequestProperty("User-Agent", getUserAgent()); mHttpConn.setConnectTimeout(getTaskConfig().getConnectTimeOut()); mHttpConn.setReadTimeout(getTaskConfig().getIOTimeOut()); - //mHttpConn.setRequestProperty("Range", "bytes=" + 0 + "-" + "100"); //内部缓冲区---分段上传防止oom mHttpConn.setChunkedStreamingMode(getTaskConfig().getBuffSize()); @@ -123,9 +123,10 @@ final class HttpUThreadTaskAdapter extends BaseHttpThreadTaskAdapter { } private String getContentType() { - return (mTaskOption.getHeaders() == null || TextUtils.isEmpty( - mTaskOption.getHeaders().get("Content-Type"))) ? "multipart/form-data" - : mTaskOption.getHeaders().get("Content-Type"); + //return (mTaskOption.getHeaders() == null || TextUtils.isEmpty( + // mTaskOption.getHeaders().get("Content-Type"))) ? "multipart/form-data" + // : mTaskOption.getHeaders().get("Content-Type"); + return "multipart/form-data"; } private String getUserAgent() { @@ -176,23 +177,23 @@ final class HttpUThreadTaskAdapter extends BaseHttpThreadTaskAdapter { FileInputStream inputStream = new FileInputStream(uploadFile); byte[] buffer = new byte[4096]; - int bytesRead; - while ((bytesRead = inputStream.read(buffer)) != -1) { - progress(bytesRead); - mOutputStream.write(buffer, 0, bytesRead); + int bytesLen; + while ((bytesLen = inputStream.read(buffer)) != -1) { + mOutputStream.write(buffer, 0, bytesLen); + progress(bytesLen); if (getThreadTask().isBreak()) { break; } if (mSpeedBandUtil != null) { - mSpeedBandUtil.limitNextBytes(bytesRead); + mSpeedBandUtil.limitNextBytes(bytesLen); } } mOutputStream.flush(); - //outputStream.close(); //不能调用,否则服务器端异常 inputStream.close(); - writer.append(LINE_END); - writer.flush(); + writer.append(LINE_END).flush(); + // 保证上传的文件和本地的一致,https://www.cnblogs.com/tugenhua0707/p/8975121.html + writer.append(PREFIX).append(BOUNDARY).append(PREFIX).append(LINE_END).flush(); } /** @@ -202,11 +203,6 @@ final class HttpUThreadTaskAdapter extends BaseHttpThreadTaskAdapter { */ private String finish(PrintWriter writer) throws IOException { StringBuilder response = new StringBuilder(); - - writer.append(LINE_END).flush(); - writer.append(PREFIX).append(BOUNDARY).append(PREFIX).append(LINE_END); - writer.flush(); - int status = mHttpConn.getResponseCode(); if (status == HttpURLConnection.HTTP_OK) { diff --git a/app/src/main/java/com/arialyy/simple/core/download/SingleTaskActivity.java b/app/src/main/java/com/arialyy/simple/core/download/SingleTaskActivity.java index 0e73526f..5d1d70ef 100644 --- a/app/src/main/java/com/arialyy/simple/core/download/SingleTaskActivity.java +++ b/app/src/main/java/com/arialyy/simple/core/download/SingleTaskActivity.java @@ -245,7 +245,7 @@ public class SingleTaskActivity extends BaseActivity { if (task.getKey().equals(mUrl)) { Toast.makeText(SingleTaskActivity.this, getString(R.string.download_success), Toast.LENGTH_SHORT).show(); - ALog.d(TAG, "文件md5: 9886e90f014d462b560dcec9c327bdb7"); + //ALog.d(TAG, "文件md5: 9886e90f014d462b560dcec9c327bdb7"); ALog.d(TAG, "下载完成的文件md5: " + CommonUtil.getFileMD5(new File(task.getFilePath()))); getBinding().pl.setInfo(task.getEntity()); } diff --git a/app/src/main/java/com/arialyy/simple/core/upload/HttpUploadActivity.java b/app/src/main/java/com/arialyy/simple/core/upload/HttpUploadActivity.java index f195346a..a8224140 100644 --- a/app/src/main/java/com/arialyy/simple/core/upload/HttpUploadActivity.java +++ b/app/src/main/java/com/arialyy/simple/core/upload/HttpUploadActivity.java @@ -40,7 +40,8 @@ import java.io.File; public class HttpUploadActivity extends BaseActivity { private static final String TAG = "HttpUploadActivity"; - private final String FILE_PATH = "/mnt/sdcard/QQMusic-import-1.2.1.zip"; + //private final String FILE_PATH = "/mnt/sdcard/QQMusic-import-1.2.1.zip"; + private final String FILE_PATH = "/mnt/sdcard/update.jpg"; //private final String FILE_PATH = // Environment.getExternalStorageDirectory().getPath() + "/Download/QQMusic-import-1.2.1.zip"; private UploadEntity mEntity; @@ -55,9 +56,11 @@ public class HttpUploadActivity extends BaseActivity { Aria.upload(this).getTaskList(); mEntity = Aria.upload(this).getFirstUploadEntity(FILE_PATH); - if (mEntity != null){ - getBinding().pl.setInfo(mEntity); + if (mEntity == null) { + mEntity = new UploadEntity(); + mEntity.setFilePath(FILE_PATH); } + getBinding().pl.setInfo(mEntity); Aria.upload(this).register(); getBinding().pl.setBtListener(new ProgressLayout.OnProgressLayoutBtListener() { @@ -86,7 +89,7 @@ public class HttpUploadActivity extends BaseActivity { option.setAttachment("file"); Aria.upload(HttpUploadActivity.this).load(FILE_PATH) //.setUploadUrl("http://lib-test.xzxyun.com:8042/Api/upload?data={\"type\":\"1\",\"fileType\":\".apk\"}") - .setUploadUrl("http://9.9.9.28:5000/upload/") + .setUploadUrl("http://172.16.0.91:5000/upload/") .ignoreFilePathOccupy() //.setTempUrl("http://192.168.1.6:8080/upload/sign_file/").setAttachment("file") //.addHeader("iplanetdirectorypro", "11a09102fb934ad0bc206f9c611d7933")