Permalink
Fetching contributors…
Cannot retrieve contributors at this time
349 lines (285 sloc) 14.7 KB

Aria

图标

ENGLISH DOC

Aria项目源于工作中遇到的一个文件下载管理的需求,当时被下载折磨的痛不欲生,从那时起便萌生了编写一个简单易用,稳当高效的下载框架,aria经历了1.0到3.0的开发,算是越来越接近当初所制定的目标了。

Aria有以下特点:

如果你觉得Aria对你有帮助,您的star和issues将是对我最大支持.^_^

下载

Download Download

compile 'com.arialyy.aria:aria-core:3.2.20'
annotationProcessor 'com.arialyy.aria:aria-compiler:3.2.20'

示例

多任务下载 网速下载限制 下载任务组

性能

性能展示


使用

由于Aria涉及到文件和网络的操作,因此需要你在manifest文件中添加以下权限,如果你希望在6.0以上的系统中使用Aria,那么你需要动态向安卓系统申请文件系统读写权限,如何使用安卓系统权限

<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

使用Aria进行下载

普通任务下载

  • 下载\恢复下载

    Aria.download(this)
        .load(DOWNLOAD_URL)     //读取下载地址
        .setDownloadPath(DOWNLOAD_PATH)    //设置文件保存的完整路径
        .start();   //启动下载
  • 暂停

    Aria.download(this).load(DOWNLOAD_URL).pause();
  • 取消下载

    Aria.download(this).load(DOWNLOAD_URL).cancel();

一组任务下载

任务组的下载和普通任务的下载基本上差不多,区别在于,任务组下载不需要对每一个子任务设置保存路径,但是需要设置任务组保存文件夹路径,所有子任务都保存在该文件夹下

  • 下载\恢复下载

    Aria.download(this)
        .load(urls)     //设置一主任务,参数为List<String>
        .setDownloadDirPath(groupDirPath)    //设置任务组的文件夹路径
        .start();   //启动下载
  • 暂停

    Aria.download(this).load(urls).pause();
  • 取消下载

    Aria.download(this).load(urls).cancel();

上传

  • 添加任务(只添加,不上传)
Aria.upload(this)
    .load(filePath)     //文件路径
    .setUploadUrl(uploadUrl)  //上传路径
    .setAttachment(fileKey)   //服务器读取文件的key
    .add();
  • 上传
Aria.upload(this)
    .load(filePath)     //文件路径
    .setUploadUrl(uploadUrl)  //上传路径
    .setAttachment(fileKey)   //服务器读取文件的key
    .start();
  • 取消上传
 Aria.upload(this).load(filePath).cancel();

FTP

单文件下载

  • 开始\恢复下载
Aria.download(this)
   .loadFtp("ftp://172.18.104.129:21/haha/large.rar")
   .login("lao", "123456")				//登录FTP服务器
   .setDownloadPath("/mnt/sdcard/")	//设置文件保存文件夹
    .start();
  • 暂停
 Aria.download(this).loadFtp(URL).stop();
  • 删除任务
 Aria.download(this).loadFtp(URL).cancel();

文件夹下载

  • 开始\恢复下载
Aria.download(this)
   .loadFtpDir("ftp://172.18.104.129:21/haha/")
   .setDownloadDirPath(downloadPath)
   .login("lao", "123456")
   .start();
  • 暂停
 Aria.download(this).loadFtpDir(dir).stop();
  • 删除任务
 Aria.download(this).loadFtpDir(dir).cancel();

单文件上传

  • 开始\恢复上传
Aria.upload(this)
	.loadFtp("/mnt/sdcard/gggg.apk") //上传文件路径
   .setUploadUrl(URL)		//上传的ftp服务器地址
   .login("lao", "123456")
   .start();
  • 暂停
 Aria.upload(this).loadFtp(FILE_PATH).stop();
  • 删除任务
Aria.upload(this).loadFtp(FILE_PATH).cancel();

任务状态获取

如果你希望读取任务进度或任务的信息,那么你需要创建事件类,并在onResume(Activity、Fragment)或构造函数(Dialog、PopupWindow),将该事件类注册到Aria管理器。

  1. 将对象注册到Aria

Aria.download(this).register();Aria.upload(this).register();

@Override
protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   Aria.download(this).register();
 }
  1. 使用 @Download@Upload@DownloadGroup 注解你的函数

注意:

  • 注解回掉采用Apt的方式实现,所以,你不需要担心这会影响你机器的性能
  • 被注解的方法不能被private修饰
  • 被注解的方法只能有一个参数,并且参数类型必须是DownloadTaskUploadTaskDownloadGroupTask
  • 方法名可以为任意字符串
  1. 除了在widget(Activity、Fragment、Dialog、Popupwindow)中使用注解方法外,你还可以在Service、Notification等组件中使用注解函数。
注解 说明 示例
@Download.onPre 预处理的注解,在任务为开始前回调(一般在此处预处理UI界面) @Download.onPre void onPre(DownloadTask task) {}
@Download.onTaskStart 任务开始时的注解,新任务开始时进行回调 @Download.onTaskStart void taskStart(DownloadTask task) {}
@Download.onTaskResume 任务恢复时的注解,任务从停止恢复到运行前进行回调 @Download.onTaskResume void taskResume(DownloadTask task) {}
@Download.onTaskRunning 任务执行时的注解,任务正在执行时进行回调 @Download.onTaskRunning void running(DownloadTask task) {}
@Download.onTaskStop 任务停止时的注解,任务停止时进行回调 @Download.onTaskStop void taskStop(DownloadTask task) {}
@Download.onTaskCancel 任务被删除时的注解,任务被删除时进行回调 @Download.onTaskCancel void taskCancel(DownloadTask task) {}
@Download.onTaskFail 任务失败时的注解,任务执行失败时进行回调 @Download.onTaskFail void taskFail(DownloadTask task) {}
@Download.onTaskComplete 任务完成时的注解,任务完成时进行回调 @Download.onTaskComplete void taskComplete(DownloadTask task) {}
@Download.onNoSupportBreakPoint 这是一个特殊的注解,用于处理不支持断点续传的任务 @Download.onNoSupportBreakPoint void onNoSupportBreakPoint(DownloadTask task) {}

TIP:如果你子希望对单个任务,或某一些特定任务设置监听器。
在注解中添加任务的下载地址,则表示只有该任务才会触发被注解的方法

@Download.onTaskRunning({
     "https://test.xx.apk",
     "http://test.xx2.apk"
 }) void taskRunning(DownloadTask task) {
   mAdapter.setProgress(task.getDownloadEntity());
 }

在上面的例子中,只有下载地址是https://test.xx.apkhttp://test.xx2.apk才会触发 taskRunning(DownloadTask task)方法。

Aria参数配置

配置文件设置参数

创建 aria_config.xml 文件,将其放在assets目录下

代码中设置参数

除了文件方式外修改Aria参数外,同样的,你也可以在代码中动态修改Aria参数
通过Aria.get(this).getDownloadConfig()Aria.get(this).getUploadConfig()直接获取配置文件,然后修改参数
如以下所示:

// 修改最大下载数,调用完成后,立即生效
// 如当前下载任务数是4,修改完成后,当前任务数会被Aria自动调度任务数
Aria.get(this).getDownloadConfig().setMaxTaskNum(3);

常用接口

api 说明
Aria.download(this).stopAllTask(); 停止所有正在下载的任务
Aria.download(this).resumeAllTask(); 恢复所有停止的任务
Aria.download(this).removeAllTask(); 删除所有任务
1、如果任务为完成,会删除没有完成的文件
2、如果使用removeAllTask(true)方法,会将已经下载完成和未完成的文件删除
3、如果是上传任务,不会删除本地的上传文件,但如果使用removeAllTask(true),同样会删除本地上传文件
Aria.download(this).setMaxSpeed(speed) 限制单个任务的上传、下载的最大速度(单位为 kb)
Aria.download(this).load(DOWNLOAD_URL)
.setExtendField(str)
设置扩展字段,有的时候,你可能希望在下载的时候存放一些自己的数据,这时你可以调用该接口将数据保存下来(如果你数据比较多,或者数据比较复杂,你可以先把数据转换为JSON,然后再将其存到Aria的下载实体中)
Aria.download(this).load(DOWNLOAD_URL)
.getExtendField()
获取保存的扩展字段
Aria.download(this).load(DOWNLOAD_URL)
.setDownloadPath(PATH).setHighestPriority();
将任务设置为最高优先级任务,最高优先级任务有以下特点:
1、在下载队列中,有且只有一个最高优先级任务
2、最高优先级任务会一直存在,直到用户手动暂停或任务完成
3、任务调度器不会暂停最高优先级任务
4、用户手动暂停或任务完成后,第二次重新执行该任务,该命令将失效
5、如果下载队列中已经满了,则会停止队尾的任务,当高优先级任务完成后,该队尾任务将自动执行
6、把任务设置为最高优先级任务后,将自动执行任务,不需要重新调用start()启动任务

任务实体常用数据

@Override public void onTaskRunning(DownloadTask task) {
  //如果你打开了速度单位转换配置,将可以通过以下方法获取带单位的下载速度,如:1 mb/s
  String convertSpeed = task.getConvertSpeed();
  //如果你有自己的单位格式,可以通过以下方法获取原始byte长度
  long speed = task.getSpeed();
}
  • 获取下载的文件大小、当前进度百分比
    同样的,你也可以在DownloadTask对象中获取下载的文件大小
@Override public void onTaskRunning(DownloadTask task) {
  //获取文件大小
  long fileSize = task.getFileSize();
  //获取单位转换后的文件大小
  String fileSize1 = task.getConvertFileSize();
  //当前进度百分比
  int percent = task.getPercent();
}

混淆配置

-dontwarn com.arialyy.aria.**
-keep class com.arialyy.aria.**{*;}
-keep class **$$DownloadListenerProxy{ *; }
-keep class **$$UploadListenerProxy{ *; }
-keep class **$$DownloadGroupListenerProxy{ *; }
-keepclasseswithmembernames class * {
    @Download.* <methods>;
    @Upload.* <methods>;
    @DownloadGroup.* <methods>;
}

其他

有任何问题,可以在issues给我留言反馈。
Aria交流群:524329160


后续版本开发规划

  • 代码优化

开发日志

  • v_3.2.17 修复一个版本兼容性问题,线程中使用Aria出错问题
  • v_3.2.15 修复大型文件分段下载失败的问题,修复中文URL乱码问题
  • v_3.2.14 修复恢复所有任务的api接口,不能恢复下载组任务的问题
  • v_3.2.13 修复某些服务器头文件返回描述文件格式错误的问题、修复有时删除任务,需要两次删除的问题
  • v_3.2.12 实现FTP多线程断点续传下载,FTP断点续传上传功能
  • v_3.2.9 修复任务组下载完成两次回掉的问题,修复又是获取不到下载状态的问题
  • v_3.2.8 修复下载超过2G大小的文件失败的问题
  • v_3.2.7 移除设置文件名的api接口,修复断开网络时出现的进度条错误的问题
  • v_3.2.6 移除广播事件,增加任务组下载功能
  • v_3.1.9 修复stopAll队列没有任务时崩溃的问题,增加针对单个任务监听的功能
  • v_3.1.7 修复某些文件下载不了的bug,增加apt注解方法,事件获取更加简单了
  • v_3.1.6 取消任务时onTaskCancel回调两次的bug
  • v_3.1.5 优化代码结构,增加优先下载任务功能。
  • v_3.1.4 修复快速切换,暂停、恢复功能时,概率性出现的重新下载问题,添加onPre()回调,onPre()用于请求地址之前执行界面UI更新操作。
  • v_3.1.0 添加Aria配置文件,优化代码

License

Copyright 2016 AriaLyy(https://github.com/AriaLyy/Aria)

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.