# 上传下载 request部件主要给应用提供上传下载文件、后台传输代理的基础能力。 > ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:** > 本模块首批接口从API version 6开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 ## 导入模块 ```js import request from '@ohos.request'; ``` ## 限制与约束 在开发FA模型下的应用程序时, 默认支持https,如果要支持http,需要在config.json里增加network标签,属性标识 "cleartextTraffic": true。即: ```js var config = { "deviceConfig": { "default": { "network": { "cleartextTraffic": true } //... } } } ``` 在开发stage模型下的应用程序时,不涉及属性标识 "cleartextTraffic"。 ## 常量 **需要权限**:ohos.permission.INTERNET **系统能力**: 以下各项对应的系统能力均为SystemCapability.MiscServices.Download。 | 名称 | 参数类型 | 可读 | 可写 | 说明 | | -------- | -------- | -------- | -------- | -------- | | NETWORK_MOBILE | number | 是 | 否 | 使用蜂窝网络时允许下载的位标志。 | | NETWORK_WIFI | number | 是 | 否 | 使用WLAN时允许下载的位标志。 | | ERROR_CANNOT_RESUME7+ | number | 是 | 否 | 某些临时错误导致的恢复下载失败。 | | ERROR_DEVICE_NOT_FOUND7+ | number | 是 | 否 | 找不到SD卡等存储设备。 | | ERROR_FILE_ALREADY_EXISTS7+ | number | 是 | 否 | 要下载的文件已存在,下载会话不能覆盖现有文件。 | | ERROR_FILE_ERROR7+ | number | 是 | 否 | 文件操作失败。 | | ERROR_HTTP_DATA_ERROR7+ | number | 是 | 否 | HTTP传输失败。 | | ERROR_INSUFFICIENT_SPACE7+ | number | 是 | 否 | 存储空间不足。 | | ERROR_TOO_MANY_REDIRECTS7+ | number | 是 | 否 | 网络重定向过多导致的错误。 | | ERROR_UNHANDLED_HTTP_CODE7+ | number | 是 | 否 | 无法识别的HTTP代码。 | | ERROR_UNKNOWN7+ | number | 是 | 否 | 未知错误。 | | PAUSED_QUEUED_FOR_WIFI7+ | number | 是 | 否 | 下载被暂停并等待WLAN连接,因为文件大小超过了使用蜂窝网络的会话允许的最大值。 | | PAUSED_UNKNOWN7+ | number | 是 | 否 | 未知原因导致暂停下载。 | | PAUSED_WAITING_FOR_NETWORK7+ | number | 是 | 否 | 由于网络问题(例如网络断开)而暂停下载。 | | PAUSED_WAITING_TO_RETRY7+ | number | 是 | 否 | 发生网络错误,将重试下载会话。 | | SESSION_FAILED7+ | number | 是 | 否 | 下载会话已失败,将不会重试。 | | SESSION_PAUSED7+ | number | 是 | 否 | 下载会话已暂停。 | | SESSION_PENDING7+ | number | 是 | 否 | 正在调度下载会话。 | | SESSION_RUNNING7+ | number | 是 | 否 | 下载会话正在进行中。 | | SESSION_SUCCESSFUL7+ | number | 是 | 否 | 下载会话已完成。 | ## request.upload upload(config: UploadConfig): Promise<UploadTask> 上传,异步方法,使用promise形式返回结果。 此接口仅可在FA模型下使用 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | config | [UploadConfig](#uploadconfig) | 是 | 上传的配置信息。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<[UploadTask](#uploadtask)> | 返回上传任务。 | **示例:** ```js let uploadTask; let uploadConfig = { url: 'https://patch', header: { key1: "value1", key2: "value2" }, method: "POST", files: [{ filename: "test", name: "test", uri: "internal://cache/test.jpg", type: "jpg" }], data: [{ name: "name123", value: "123" }], }; request.upload(uploadConfig).then((data) => { uploadTask = data; }).catch((err) => { console.error('Failed to request the upload. Cause: ' + JSON.stringify(err)); }) ``` ## request.upload upload(config: UploadConfig, callback: AsyncCallback<UploadTask>): void 上传,异步方法,使用callback形式返回结果。 此接口仅可在FA模型下使用 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | config | [UploadConfig](#uploadconfig) | 是 | 上传的配置信息。 | | callback | AsyncCallback<[UploadTask](#uploadtask)> | 否 | 回调函数,异步返回UploadTask对象。 | **示例:** ```js let uploadTask; let uploadConfig = { url: 'https://patch', header: { key1: "value1", key2: "value2" }, method: "POST", files: [{ filename: "test", name: "test", uri: "internal://cache/test.jpg", type: "jpg" }], data: [{ name: "name123", value: "123" }], }; request.upload(uploadConfig, (err, data) => { if (err) { console.error('Failed to request the upload. Cause: ' + JSON.stringify(err)); return; } uploadTask = data; }); ``` ## request.upload9+ upload(context: BaseContext, config: UploadConfig): Promise<UploadTask> 上传,异步方法,使用promise形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | context | BaseContext | 是 | 基于应用程序的上下文。 | | config | [UploadConfig](#uploadconfig) | 是 | 上传的配置信息。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<[UploadTask](#uploadtask)> | 返回上传任务。 | **示例:** ```js let uploadTask; let uploadConfig = { url: 'https://patch', header: { key1: "value1", key2: "value2" }, method: "POST", files: { filename: "test", name: "test", uri: "internal://cache/test.jpg", type: "jpg" }, data: { name: "name123", value: "123" }, }; request.upload(globalThis.abilityContext, uploadConfig).then((data) => { uploadTask = data; }).catch((err) => { console.error('Failed to request the upload. Cause: ' + JSON.stringify(err)); }); ``` ## request.upload9+ upload(context: BaseContext, config: UploadConfig, callback: AsyncCallback<UploadTask>): void 上传,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | context | BaseContext | 是 | 基于应用程序的上下文。 | | config | [UploadConfig](#uploadconfig) | 是 | 上传的配置信息。 | | callback | AsyncCallback<[UploadTask](#uploadtask)> | 否 | 回调函数,异步返回UploadTask对象。 | **示例:** ```js let uploadTask; let uploadConfig = { url: 'https://patch', header: { key1: "value1", key2: "value2" }, method: "POST", files: [{ filename: "test", name: "test", uri: "internal://cache/test.jpg", type: "jpg" }], data: [{ name: "name123", value: "123" }], }; request.upload(globalThis.abilityContext, uploadConfig, (err, data) => { if (err) { console.error('Failed to request the upload. Cause: ' + JSON.stringify(err)); return; } uploadTask = data; }); ``` ## UploadTask 上传任务,使用下列方法前,需要先获取UploadTask对象。 ### on('progress') on(type: 'progress', callback:(uploadedSize: number, totalSize: number) => void): void 开启上传任务监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 订阅的事件类型,取值为'progress'(上传的进度信息)。 | | callback | function | 是 | 上传进度的回调函数。 | 回调函数的参数 | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | uploadedSize | number | 是 | 当前已上传文件大小,单位为KB。 | | totalSize | number | 是 | 上传文件的总大小,单位为KB。 | **示例:** ```js uploadTask.on('progress', function callback(uploadedSize, totalSize) { console.info("upload totalSize:" + totalSize + " uploadedSize:" + uploadedSize); } ); ``` ### on('headerReceive')7+ on(type: 'headerReceive', callback: (header: object) => void): void 开启上传任务监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 订阅的事件类型,取值为'headerReceive'(接收响应头)。 | | callback | function | 是 | HTTP Response Header事件的回调函数。 | 回调函数的参数: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | header | object | 是 | HTTP Response Header。 | **示例:** ```js uploadTask.on('headerReceive', function callback(headers){ console.info("upOnHeader headers:" + JSON.stringify(headers)); } ); ``` ### off('progress') off(type: 'progress', callback?: (uploadedSize: number, totalSize: number) => void): void 关闭上传任务监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 取消订阅的事件类型,取值为'progress'(上传的进度信息)。 | | callback | function | 否 | 上传任务的回调函数。 | 回调函数的参数: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | uploadedSize | number | 是 | 当前已上传文件的大小,单位为KB。 | | totalSize | number | 是 | 上传文件的总大小,单位为KB。 | **示例:** ```js uploadTask.off('progress', function callback(uploadedSize, totalSize) { console.info('uploadedSize: ' + uploadedSize, 'totalSize: ' + totalSize); } ); ``` ### off('headerReceive')7+ off(type: 'headerReceive', callback?: (header: object) => void): void 关闭上传任务监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 取消订阅的事件类型,取值为'headerReceive'(接收响应头)。 | | callback | function | 否 | HTTP Response Header事件的回调函数。 | 回调函数的参数: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | header | object | 是 | HTTP Response Header。 | **示例:** ```js uploadTask.off('headerReceive', function callback(headers) { console.info("upOnHeader headers:" + JSON.stringify(headers)); } ); ``` ### remove remove(): Promise<boolean> 移除上传的任务,异步方法,使用promise形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<boolean> | 移除任务是否成功。true:成功,false:不成功。 | **示例:** ```js uploadTask.remove().then((result) => { if (result) { console.info('Upload task removed successfully. '); } else { console.error('Failed to remove the upload task. '); } }).catch((err) => { console.error('Failed to remove the upload task. Cause: ' + JSON.stringify(err)); }); ``` ### remove remove(callback: AsyncCallback<boolean>): void 移除上传的任务,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Upload **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<boolean> | 是 | 移除任务的回调函数。 | **示例:** ```js uploadTask.remove((err, result) => { if (err) { console.error('Failed to remove the upload task. Cause: ' + JSON.stringify(err)); return; } if (result) { console.info('Upload task removed successfully.'); } else { console.error('Failed to remove the upload task.'); } }); ``` ## UploadConfig **需要权限**:ohos.permission.INTERNET **系统能力**: 以下各项对应的系统能力均为SystemCapability.MiscServices.Upload。 | 名称 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | url | string | 是 | 资源地址。 | | header | object | 是 | 添加要包含在上载请求中的HTTP或HTTPS标志头。 | | method | string | 是 | 请求方法:POST、PUT。缺省为POST。 | | files | Array<[File](#file)> | 是 | 要上传的文件列表。请使用 multipart/form-data提交。 | | data | Array<[RequestData](#requestdata)> | 是 | 请求的表单数据。 | ## File **需要权限**:ohos.permission.INTERNET **系统能力**: 以下各项对应的系统能力均为SystemCapability.MiscServices.Download | 名称 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | filename | string | 否 | multipart提交时,请求头中的文件名。 | | name | string | 否 | multipart提交时,表单项目的名称,缺省为file。 | | uri | string | 是 | 文件的本地存储路径。
支持“dataability”和“internal”两种协议类型,但“internal”仅支持临时目录,示例:
dataability:///com.domainname.dataability.persondata/person/10/file.txt
internal://cache/path/to/file.txt | | type | string | 否 | 文件的内容类型,默认根据文件名或路径的后缀获取。 | ## RequestData **需要权限**:ohos.permission.INTERNET **系统能力**: 以下各项对应的系统能力均为SystemCapability.MiscServices.Download | 名称 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | name | string | 是 | 表示表单元素的名称。 | | value | string | 是 | 表示表单元素的值。 | ## request.download download(config: DownloadConfig): Promise<DownloadTask> 下载,异步方法,使用promise形式返回结果。 此接口仅可在FA模型下使用 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | config | [DownloadConfig](#downloadconfig) | 是 | 下载的配置信息。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<[DownloadTask](#downloadtask)> | 返回下载任务。 | **示例:** ```js let downloadTask; request.download({ url: 'https://xxxx/xxxx.hap' }).then((data) => { downloadTask = data; }).catch((err) => { console.error('Failed to request the download. Cause: ' + JSON.stringify(err)); }) ``` ## request.download download(config: DownloadConfig, callback: AsyncCallback<DownloadTask>): void 下载,异步方法,使用callback形式返回结果。 此接口仅可在FA模型下使用 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | config | [DownloadConfig](#downloadconfig) | 是 | 下载的配置信息。 | | callback | AsyncCallback<[DownloadTask](#downloadtask)> | 否 | 下载接口的回调函数。 | **示例:** ```js let downloadTask; request.download({ url: 'https://xxxx/xxxxx.hap', filePath: 'xxx/xxxxx.hap'}, (err, data) => { if (err) { console.error('Failed to request the download. Cause: ' + JSON.stringify(err)); return; } downloadTask = data; }); ``` ## request.download9+ download(context: BaseContext, config: DownloadConfig): Promise<DownloadTask> 下载,异步方法,使用promise形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | context | BaseContext | 是 | 基于应用程序的上下文。 | | config | [DownloadConfig](#downloadconfig) | 是 | 下载的配置信息。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<[DownloadTask](#downloadtask)> | 返回下载任务。 | **示例:** ```js let downloadTask; request.download(globalThis.abilityContext, { url: 'https://xxxx/xxxx.hap' }).then((data) => { downloadTask = data; }).catch((err) => { console.error('Failed to request the download. Cause: ' + JSON.stringify(err)); }) ``` ## request.download9+ download(context: BaseContext, config: DownloadConfig, callback: AsyncCallback<DownloadTask>): void; 下载,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | context | BaseContext | 是 | 基于应用程序的上下文。 | | config | [DownloadConfig](#downloadconfig) | 是 | 下载的配置信息。 | | callback | AsyncCallback<[DownloadTask](#downloadtask)> | 否 | 下载接口的回调函数。 | **示例:** ```js let downloadTask; request.download(globalThis.abilityContext, { url: 'https://xxxx/xxxxx.hap', filePath: 'xxx/xxxxx.hap'}, (err, data) => { if (err) { console.error('Failed to request the download. Cause: ' + JSON.stringify(err)); return; } downloadTask = data; }); ``` ## DownloadTask 下载任务。 ### on('progress') on(type: 'progress', callback:(receivedSize: number, totalSize: number) => void): void 开启下载任务监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 订阅的事件类型,取值为'progress'(下载的进度信息)。 | | callback | function | 是 | 下载的回调函数。 | 回调函数的参数: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | receivedSize | number | 是 | 当前下载的进度,单位为KB。 | | totalSize | number | 是 | 下载文件的总大小,单位为KB。 | **示例:** ```js downloadTask.on('progress', function download_callback(receivedSize, totalSize) { console.info("download receivedSize:" + receivedSize + " totalSize:" + totalSize); } ); ``` ### off('progress') off(type: 'progress', callback?: (receivedSize: number, totalSize: number) => void): void 关闭下载任务监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 取消订阅的事件类型,取值为'progress'(下载的进度信息)。 | | callback | function | 否 | 下载任务的回调函数。 | 回调函数的参数: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | receivedSize | number | 是 | 当前下载的进度。 | | totalSize | number | 是 | 下载文件的总大小。 | **示例:** ```js downloadTask .off('progress', function download_callback(receivedSize, totalSize) { console.info("download receivedSize:" + receivedSize + " totalSize:" + totalSize); } ); ``` ### on('complete'|'pause'|'remove')7+ on(type: 'complete'|'pause'|'remove', callback:() => void): void 开启下载任务相关的监听,异步方法,使用callback形式返回。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 订阅的事件类型。
- 取值为'complete',表示下载任务完成;
- 取值为'pause',表示下载任务暂停;
- 取值为'remove',表示下载任务移除。 | | callback | function | 是 | 回调函数。 | **示例:** ```js downloadTask.on('complete', function callback() { console.info('Download task completed.'); } ); ``` ### off('complete'|'pause'|'remove')7+ off(type: 'complete'|'pause'|'remove', callback?:() => void): void 取消下载任务相关的监听,异步方法,使用callback形式返回。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 取消订阅的事件类型。
- 取值为'complete',表示下载任务完成;
- 取值为'pause',表示下载任务暂停;
- 取值为'remove',表示下载任务移除。 | | callback | function | 否 | 回调函数。 | **示例:** ```js downloadTask.off('complete', function callback() { console.info('Download task completed.'); } ); ``` ### on('fail')7+ on(type: 'fail', callback: (err: number) => void): void 开启下载任务失败监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 订阅的事件类型,取值为'fail'(下载失败)。 | | callback | function | 是 | 下载失败的回调函数。 | 回调函数的参数: | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | err | number | 是 | 下载失败的错误码,错误原因见[ERROR.*](#常量)。 | **示例:** ```js downloadTask.on('fail', function callBack(err) { console.info('Download task failed. Cause:' + err); } ); ``` ### off('fail')7+ off(type: 'fail', callback?: (err: number) => void): void 取消下载任务失败监听,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 取消订阅的事件类型,取值为'fail'(下载失败)。 | | callback | function | 否 | 取消下载失败的回调函数。 | 回调函数的参数 | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | err | number | 是 | 下载失败的错误码。错误原因见[ERROR_*](#常量)。 | **示例:** ```js downloadTask.off('fail', function callBack(err) { console.info('Download task failed. Cause:' + err); } ); ``` ### remove remove(): Promise<boolean> 移除下载的任务,异步方法,使用promise形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<boolean> | 移除任务是否成功。 | **示例:** ```js downloadTask.remove().then((result) => { if (result) { console.info('Download task removed.'); } else { console.error('Failed to remove the download task.'); } }).catch ((err) => { console.error('Failed to remove the download task.'); }); ``` ### remove remove(callback: AsyncCallback<boolean>): void 移除下载的任务,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<boolean> | 是 | 移除任务是否成功。 | **示例:** ```js downloadTask.remove((err, result)=>{ if(err) { console.error('Failed to remove the download task.'); return; } if (result) { console.info('Download task removed.'); } else { console.error('Failed to remove the download task.'); } }); ``` ### query7+ query(): Promise<DownloadInfo> 查询下载任务,异步方法,使用promise形式返回DownloadInfo里的信息。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 类型 | 说明 | | -------- | -------- | | Promise<[DownloadInfo](#downloadinfo7)> | 查询下载任务信息。 | **示例:** ```js downloadTask.query().then((downloadInfo) => { console.info('Download task queried. Data:' + JSON.stringify(downloadInfo)) }) .catch((err) => { console.error('Failed to query the download task. Cause:' + err) }); ``` ### query7+ query(callback: AsyncCallback<DownloadInfo>): void 查询下载的任务,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<[DownloadInfo](#downloadinfo7)> | 是 | 查询下载任务的回调函数。 | **示例:** ```js downloadTask.query((err, downloadInfo)=>{ if(err) { console.error('Failed to query the download mimeType. Cause:' + JSON.stringify(err)); } else { console.info('download query success. data:'+ JSON.stringify(downloadInfo)); } }); ``` ### queryMimeType7+ queryMimeType(): Promise<string> 查询下载的任务的 MimeType,异步方法,使用promise形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<string> | 查询下载任务的MimeType。 | **示例:** ```js downloadTask.queryMimeType().then((data) => { console.info('Download task queried. Data:' + JSON.stringify(data)); }).catch((err) => { console.error('Failed to query the download MimeType. Cause:' + JSON.stringify(err)) }); ``` ### queryMimeType7+ queryMimeType(callback: AsyncCallback<string>): void; 查询下载的任务的 MimeType,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<string> | 是 | 查询下载任务的MimeType的回调函数。 | **示例:** ```js downloadTask.queryMimeType((err, data)=>{ if(err) { console.error('Failed to query the download mimeType. Cause:' + JSON.stringify(err)); } else { console.info('Download task queried. data:' + JSON.stringify(data)); } }); ``` ### pause7+ pause(): Promise<void> 暂停下载任务,异步方法,使用promise形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<void> | 暂停下载任务是否成功。 | **示例:** ```js downloadTask.pause().then((result) => { if (result) { console.info('Download task paused. '); } else { console.error('Failed to pause the download task. Cause:' + JSON.stringify(result)); } }).catch((err) => { console.error('Failed to pause the download task. Cause:' + JSON.stringify(err)); }); ``` ### pause7+ pause(callback: AsyncCallback<void>): void 暂停下载任务,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<void> | 是 | 暂停下载任务的回调函数。 | **示例:** ```js downloadTask.pause((err, result)=>{ if(err) { console.error('Failed to pause the download task. Cause:' + JSON.stringify(err)); return; } if (result) { console.info('Download task paused. '); } else { console.error('Failed to pause the download task. Cause:' + JSON.stringify(result)); } }); ``` ### resume7+ resume(): Promise<void> 重新启动暂停的下载任务,异步方法,使用promise形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 类型 | 说明 | | -------- | -------- | | Promise<void> | 重新启动暂停的下载任务是否成功。 | **示例:** ```js downloadTask.resume().then((result) => { if (result) { console.info('Download task resumed.') } else { console.error('Failed to resume the download task. '); } console.info('Download task resumed.') }).catch((err) => { console.error('Failed to resume the download task. Cause:' + err); }); ``` ### resume7+ resume(callback: AsyncCallback<void>): void 重新启动暂停的下载任务,异步方法,使用callback形式返回结果。 **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download **参数:** | 参数名 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<void> | 是 | 重新启动暂停的下载任务的回调函数。 | **示例:** ```js downloadTask.resume((err, result)=>{ if (err) { console.error('Failed to resume the download task. Cause:' + err); return; } if (result) { console.info('Download task resumed.'); } else { console.error('Failed to resume the download task.'); } }); ``` ## DownloadConfig **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download | 名称 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | url | string | 是 | 资源地址。 | | header | object | 否 | 添加要包含在下载请求中的HTTP或HTTPS标志头。 | | enableMetered | boolean | 否 | 设置是否允许在按流量计费的连接下下载。
- true:是
- false:否 | | enableRoaming | boolean | 否 | 设置是否允许在漫游网络中下载。
- true:是
- false:否| | description | string | 否 | 设置下载会话的描述。 | | filePath7+ | string | 否 | 设置下载路径(默认在'internal://cache/'路径下)。
- filePath:'workspace/test.txt':默认路径下创建workspace路径,并将文件存储在workspace路径下。
- filePath:'test.txt':将文件存储在默认路径下。
- filePath:'workspace/':默认路径下创建workspace路径,并将文件存储在workspace路径下。 | | networkType | number | 否 | 设置允许下载的网络类型。
- NETWORK_MOBILE:0x00000001
- NETWORK_WIFI:0x00010000| | title | string | 否 | 设置下载会话标题。 | | background | boolean | 否 | 后台任务通知开关,开启后可在通知中显示下载状态。 | ## DownloadInfo7+ **需要权限**:ohos.permission.INTERNET **系统能力**: SystemCapability.MiscServices.Download | 名称 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | downloadId | number | 是 | 下载的文件ID。 | | failedReason | number | 否 | 下载失败原因,可以是任何[ERROR_*](#常量)常量。 | | fileName | string | 是 | 下载的文件名。 | | filePath | string | 是 | 存储文件的URI。 | | pausedReason | number | 否 | 会话暂停的原因,可以是任何[PAUSED_*](#常量)常量。 | | status | number | 是 | 下载状态代码,可以是任何[SESSION_*](#常量)常量。 | | targetURI | string | 是 | 下载文件的URI。 | | downloadTitle | string | 是 | 下载的文件的标题。 | | downloadTotalBytes | number | 是 | 下载的文件的总大小(int bytes)。 | | description | string | 是 | 待下载文件的描述信息。 | | downloadedBytes | number | 是 | 实时下载大小(int  bytes)。 |