# @ohos.application.uriPermissionManager(URI权限管理) > **说明:** > > 本模块首批接口从API version 10 开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 URI权限管理模块。用于应用A授权/撤销授权URI给应用B ## 导入模块 ```js import uriPermissionManager from '@ohos.application.uriPermissionManager'; ``` ## uriPermissionManager.grantUriPermission grantUriPermission(uri: string, flag: wantConstant.Flags, accessTokenId: number, callback: AsyncCallback<number>): void 授权URI给指定应用,通过callback返回结果。 默认仅允许授权属于应用自身的URI,若拥有权限ohos.permission.PROXY_AUTHORIZATION_URI则无限制。 **系统能力**:SystemCapability.Ability.AbilityRuntime.Core **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | uri | string | 是 | 指向文件的URI,例如fileshare:///com.samples.filesharetest.FileShare/person/10。 | | flag | [wantConstant.Flags](js-apis-ability-wantConstant.md#wantconstantflags) | 是 | URI的读权限或写权限。 | | targetBundleName | string | 是 | 被授权URI的应用包名 | | callback | AsyncCallback<number> | 是 | callback形式返回检验结果,返回0表示有权限,返回-1表示无权限。 | **错误码:** | 错误码ID | 错误信息 | | ------- | -------------------------------- | | 201 | Permission denied. | | 202 | Not System App. Interface caller is not a system app. | | 401 | The parameter check failed. | | 16000050 | Internal error. | | 16000058 | Invalid URI flag. | | 16000059 | Invalid URI type. | | 16000060 | Sandbox application can not grant URI permission. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例:** ```js import uriPermissionManager from '@ohos.application.uriPermissionManager'; import WantConstant from '@ohos.ability.wantConstant'; import fileio from '@ohos.fileio'; import fileUri from '@ohos.file.fileuri'; let targetBundleName = 'com.example.test_case1' let path = this.context.filesDir + '/newDir'; await fileio.mkdir(path, function (err) { if (err) { hilog.info(0x0000, 'testTag', "mkdir error"+err.message); } else { hilog.info(0x0000, 'testTag', "mkdir succeed"); } }); let uri = fileUri.getUriFromPath(path); uriPermissionManager.grantUriPermission(uri, WantConstant.Flags.FLAG_AUTH_READ_URI_PERMISSION, targetBundleName, (result) => { console.log("result.code = " + result.code) }) ``` ## uriPermissionManager.grantUriPermission grantUriPermission(uri: string, flag: wantConstant.Flags, accessTokenId: number): Promise<number> 授权URI给指定应用,通过返回值返回结果。 默认仅允许授权属于应用自身的URI,若拥有权限ohos.permission.PROXY_AUTHORIZATION_URI则无限制。 **系统能力**:SystemCapability.Ability.AbilityRuntime.Core **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | uri | string | 是 | 指向文件的URI,例如fileshare:///com.samples.filesharetest.FileShare/person/10。 | | flag | [wantConstant.Flags](js-apis-ability-wantConstant.md#wantconstantflags) | 是 | URI的读权限或写权限。 | | targetBundleName | string | 是 | 被授权URI的应用包名 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<number> | 返回0表示有权限,返回-1表示无权限。 | **错误码:** | 错误码ID | 错误信息 | | ------- | -------------------------------- | | 201 | Permission denied. | | 202 | Not System App. Interface caller is not a system app. | | 401 | The parameter check failed. | | 16000050 | Internal error. | | 16000058 | Invalid URI flag. | | 16000059 | Invalid URI type. | | 16000060 | Sandbox application can not grant URI permission. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例:** ```js import uriPermissionManager from '@ohos.application.uriPermissionManager'; import WantConstant from '@ohos.ability.wantConstant'; import fileio from '@ohos.fileio'; import fileUri from '@ohos.file.fileuri'; let targetBundleName = 'com.example.test_case1' let path = this.context.filesDir + '/newDir'; await fileio.mkdir(path, function (err) { if (err) { hilog.info(0x0000, 'testTag', "mkdir error"+err.message); } else { hilog.info(0x0000, 'testTag', "mkdir succeed"); } }); let uri = fileUri.getUriFromPath(path); uriPermissionManager.grantUriPermission(uri, wantConstant.Flags.FLAG_AUTH_READ_URI_PERMISSION, targetBundleName) .then((data) => { console.log('Verification succeeded.' + data) }).catch((error) => { console.log('Verification failed.'); }) ``` ## uriPermissionManager.revokeUriPermission revokeUriPermission(uri: string, accessTokenId: number, callback: AsyncCallback<number>): void 撤销授权指定应用的URI,通过callback返回结果。 默认仅允许撤销应用自身获得的其他应用URI,或应用授权给其他应用属于自身的URI。若拥有权限ohos.permission.PROXY_AUTHORIZATION_URI则无限制。 **系统能力**:SystemCapability.Ability.AbilityRuntime.Core **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | uri | string | 是 | 指向文件的URI,例如fileshare:///com.samples.filesharetest.FileShare/person/10。 | | targetBundleName | string | 是 | 被撤销授权uri的应用包名 | | callback | AsyncCallback<number> | 是 | callback形式返回检验结果,返回0表示有权限,返回-1表示无权限。 | **错误码:** | 错误码ID | 错误信息 | | ------- | -------------------------------- | | 201 | Permission denied. | | 202 | Not System App. Interface caller is not a system app. | | 401 | The parameter check failed. | | 16000050 | Internal error. | | 16000059 | Invalid URI type. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例:** ```js import uriPermissionManager from '@ohos.application.uriPermissionManager'; import WantConstant from '@ohos.ability.wantConstant'; let targetBundleName = 'com.example.test_case1' let uri = "file:///com.samples.filesharetest.FileShare/person/10" uriPermissionManager.revokeUriPermission(uri, targetBundleName, (result) => { console.log("result.code = " + result.code) }) ``` ## uriPermissionManager.revokeUriPermission revokeUriPermission(uri: string, flag: wantConstant.Flags, accessTokenId: number): Promise<number> 撤销授权指定应用的URI,通过返回值返回结果。 默认仅允许撤销应用自身获得的其他应用URI,或应用授权给其他应用属于自身的URI。若拥有权限ohos.permission.PROXY_AUTHORIZATION_URI则无限制。 **系统能力**:SystemCapability.Ability.AbilityRuntime.Core **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | uri | string | 是 | 指向文件的URI,例如fileshare:///com.samples.filesharetest.FileShare/person/10。 | | targetBundleName | string | 是 | 被授权URI的应用包名 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<number> | 返回0表示有权限,返回-1表示无权限。 | **错误码:** | 错误码ID | 错误信息 | | ------- | -------------------------------- | | 201 | Permission denied. | | 202 | Not System App. Interface caller is not a system app. | | 401 | The parameter check failed. | | 16000050 | Internal error. | | 16000059 | Invalid URI type. | 以上错误码详细介绍请参考[errcode-ability](../errorcodes/errorcode-ability.md)。 **示例:** ```js import uriPermissionManager from '@ohos.application.uriPermissionManager'; import WantConstant from '@ohos.ability.wantConstant'; let targetBundleName = 'com.example.test_case1' let uri = "file:///com.samples.filesharetest.FileShare/person/10" uriPermissionManager.revokeUriPermission(uri, targetBundleName) .then((data) => { console.log('Verification succeeded.' + data) }).catch((error) => { console.log('Verification failed.'); }) ```