DownloadManager下载管理

 从Android2.3开始新增了一个下载管理类,在SDK的文档中我们查找android.app.DownloadManager可以看到。下载管理类可以长期处理多个HTTP下载任务,客户端只需要给出请求的Uri和存放目标文件的位置即可,下载管理使用了一个AIDL服务器所以可以放心的在后台执行,同时实例化的方法需要使用getSystemService(Context.DOWNLOAD_SERVICE),Android123再次提醒使用APILevel为9的用户可以轻松的通过新增的这个API实现Android平台上的文件下载操作。

 DownloadManager类提供了以下几种方法来处理,

  long enqueue(DownloadManager.Requestrequest)   //存入队列一个新的下载项

 ParcelFileDescriptor openDownloadedFile(long id) //打开一个下载后的文件用于读取,参数中的long型id是一个provider中的一条记录。

Cursor  query(DownloadManager.Queryquery)  //查询一个下载,返回一个Cursor

int  remove(long... ids) //取消下载同时移除这些条从下载管理中。

 我们可以看到提供的方法都比较简单,给我们操作的最终封装成为一个provider数据库的方式进行添加、查询和移除,但是对于查询和添加任务的细节,我们要看看DownloadManager.Request类和DownloadManager.Query类了。

  一、DownloadManager.Request类的成员和定义

DownloadManager.Request  addRequestHeader(Stringheader, String value)  //添加一个Http请求报头,对于这两个参数,Android开发网给大家举个小例子,比如说User-Agent值可以为Android123或WindowsXP等等了,主要是给服务器提供标识。
DownloadManager.Request setAllowedNetworkTypes(int flags) //设置允许使用的网络类型,这一步Android2.3做的很好,目前有两种定义分别为NETWORK_MOBILE和NETWORK_WIFI我们可以选择使用移动网络或Wifi方式来下载。
DownloadManager.Request setAllowedOverRoaming(boolean allowed) //对于下载,考虑到流量费用,这里是否允许使用漫游。
DownloadManager.Request setDescription(CharSequence description) //设置一个描述信息,主要是最终显示的notification提示,可以随便写个自己区别
DownloadManager.Request setDestinationInExternalFilesDir(Context context, String dirType,String subPath)  //设置目标存储在外部目录,一般位置可以用getExternalFilesDir()方法获取。
DownloadManager.Request setDestinationInExternalPublicDir(String dirType, StringsubPath) //设置外部存储的公共目录,一般通过getExternalStoragePublicDirectory()方法获取。
DownloadManager.Request  setDestinationUri(Uriuri)  //设置需要下载目标的Uri,可以是http、ftp等等了。
DownloadManager.Request  setMimeType(StringmimeType) //设置mime类型,这里看服务器配置,一般国家化的都为utf-8编码。
DownloadManager.Request setShowRunningNotification(boolean show) //是否显示下载进度的提示
DownloadManager.Request  setTitle(CharSequencetitle)  //设置notification的标题
DownloadManager.Request setVisibleInDownloadsUi(boolean isVisible) //设置下载管理类在处理过程中的界面是否显示

 当然了Google还提供了一个简单的方法来实例化本类,这个构造方法为DownloadManager.Request(Uri uri),我们直接填写一个Uri即可,上面的设置使用默认情况。

二、DownloadManager.Query类

 对于当前下载内容的状态,我们可以使用DownloadManager.Query类来获取,本类比较简单,仅仅提供了两个方法。

  DownloadManager.Query setFilterById(long... ids)  //根据id来过滤查找。
  DownloadManager.Query setFilterByStatus(int flags) //根据任务的状态来查找。

  详细的状态在android.app.DownloadManager类中有定义,目前Android2.3中的定义为:

int STATUS_FAILED 失败
int STATUS_PAUSED 暂停
int STATUS_PENDING 等待将开始
int STATUS_RUNNING 正在处理中
int STATUS_SUCCESSFUL 已经下载成功

 最后Android开发网提醒大家要说的是因为DownloadManager类提供的query方法返回一个Cursor对象,这些状态保存在这个游标的COLUMN_STATUS字段中。

  1. 下载的状态完成均是以广播的形式通知大家,目前APILevel为9定义了下面三种Intent的action

  ACTION_DOWNLOAD_COMPLETE下载完成的动作。
  ACTION_NOTIFICATION_CLICKED当用户单击notification中下载管理的某项时触发。
  ACTION_VIEW_DOWNLOADS 查看下载项

  2.对于一个尚未完成的项,在Cursor中我们查找COLUMN_REASON字段,可能有以下定义:

int ERROR_CANNOT_RESUME 不能够继续,由于一些其他原因。 
int ERROR_DEVICE_NOT_FOUND外部存储设备没有找到,比如SD卡没有插入。 
int ERROR_FILE_ALREADY_EXISTS要下载的文件已经存在了,Android123提示下载管理类是不会覆盖已经存在的文件,所以如果需要重新下载,请先删除以前的文件。

int ERROR_FILE_ERROR 可能由于SD卡原因导致了文件错误。 
int ERROR_HTTP_DATA_ERROR在Http传输过程中出现了问题。 
int ERROR_INSUFFICIENT_SPACE 由于SD卡空间不足造成的 

int ERROR_TOO_MANY_REDIRECTS 这个Http有太多的重定向,导致无法正常下载
int ERROR_UNHANDLED_HTTP_CODE无法获取http出错的原因,比如说远程服务器没有响应。 
int ERROR_UNKNOWN 未知的错误类型.

 3. 有关暂停的一些状态,同样COLUMN_REASON字段的值可能是以下定义

int PAUSED_QUEUED_FOR_WIFI由于移动网络数据问题,等待WiFi连接能用后再重新进入下载队列。 
int PAUSED_UNKNOWN 未知原因导致了任务下载的暂停. 
int PAUSED_WAITING_FOR_NETWORK可能由于没有网络连接而无法下载,等待有可用的网络连接恢复。. 
int PAUSED_WAITING_TO_RETRY 由于重重原因导致下载暂停,等待重试。

  有关Android2.3中新增的下载管理DownloadManager的介绍基本上已经完全讲完,如果你对Cursor、Provider这些基础概念了解的话,可以看到这个下载管理类可以帮我们减少很多不必要的代码编写。


列子:
1. 首先得在AndroidManifest.xml文件设置权限
  <uses-permissionandroid:name="android.permission.INTERNET"/>//联网权限
  <uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

2.代码如下
StringUrl="http://www.allwinnertech.com/update/Update.apk";//下载地址
final DownloadManager dmg=(DownloadManager)getSystemService(DOWNLOAD_SERVICE);//获取系统service
Uri uri=Uri.parse(Url);//解析Url
Request request=newDownloadManager.Request(uri);//新建下载请求
request.setTitle("Demo"); //下载名称设置
request.setDescription("Update.apk"); //下载的描述
request.setDestinationInExternal PublicDir(Environment.DIRECTORY_DOWNLOADS,"Update.apk");//设置保存路径
request.setShowRunningNotificati on(true); //下状态栏发送下载通知
final long downloadId=dmg.enqueue(request);//启动下载
  new Thread(){//开启新的线程查询下载状态
    @Override
    public void run(){
      while(true){
    try {
      Cursor c = dmg.query(newDownloadManager.Query().setFilterById(downloadId));
      c.moveToFirst(); 
      Log.v(TAG,"status="+c.getInt(7));
      Log.v(TAG,"total_size="+c.getInt(c.getColumnIndex(DownloadManager.COLUMN_TOTAL_SIZE_BYTES)));
    //下载文件总大小    Log.v(TAG,"count_size="+c.getInt(c.getColumnIndex(DownloadManager.COLUMN_BYTES_DOWNLOADED_SO_FAR)));  //累计已经下载了文件大小     if(dmg.STATUS_SUCCESSFUL==c.getInt(c.getColumnIndex(DownloadManager.COLUMN_STATUS))){//下载完毕
        Log.v(TAG,"download finish");
        break;
        }
    Thread.sleep(100);
    } catch(InterruptedException e) {
    // TODO Auto-generatedcatch block
    e.printStackTrace();
    } 
        }
    }
   
    }.start();


你可能感兴趣的:(DownloadManager下载管理)