管理应用账号

应用开发者可以使用@ohos.account.appAccount管理本应用的账号数据。

能力限制:应用卸载场景下,被卸载应用的账号数据会被删除;本地账号删除场景下,被删除本地账号下的所有应用的账号数据会被删除。

开发准备

  1. 导入应用账号模块。

import { appAccount, BusinessError } from '@kit.BasicServicesKit';
  1. 获取应用账号的实例对象。

const appAccountManager = appAccount.createAppAccountManager();

创建应用账号

用户在应用中登录后,开发者可以在系统中创建一个关联的应用账号,后续可以基于此账号进行数据管理。

具体开发实例如下:

  1. 参数准备,指定账号名和可选配置。

    let name: string = 'ZhangSan';
    let options: appAccount.CreateAccountOptions = {
      customData: {
        age: '10'
      }
    };
  1. 调用createAccount接口,根据名称和选项创建应用账号。

    appAccountManager.createAccount(name, options).then(()=>{
      console.info('createAccount successfully');
	// ···
    }).catch((err: BusinessError)=>{
       console.error(`createAccount failed, error: code is ${err.code}, message is ${err.message}`);
	// ···
    });

查询应用账号列表

具体开发实例如下:

调用getAllAccounts接口查询账号列表。

    appAccountManager.getAllAccounts().then((data: appAccount.AppAccountInfo[]) => {
      console.info('getAllAccounts successfully, data: ' + JSON.stringify(data));
	// ···
    }).catch((err: BusinessError) => {
      console.error(`getAllAccounts failed, code is ${err.code}, message is ${err.message}`);
	// ···
    });

存取账号的凭据

具体开发实例如下:

  1. 准备参数,指定账号名、凭据类型和凭据。

    let name: string = 'ZhangSan';
    let credentialType: string = 'PIN_SIX';
    let credential: string = 'xxxxxx';
  1. 调用getCredential接口,获取账号的凭据。

    appAccountManager.getCredential(name, credentialType).then((data: string) => {
      console.info('getCredential successfully, data: ' + data);
	// ···
    }).catch((err: BusinessError) => {
      console.error(`getCredential failed, code is ${err.code}, message is ${err.message}`);
	// ···
    });
  1. 调用setCredential接口,设置账号的凭据。

    await appAccountManager.setCredential(name, credentialType, credential).then(() => {
      console.info('setCredential successfully');
    }).catch((err: BusinessError) => {
      console.error(`setCredential failed: code is ${err.code}, message is ${err.message}`);
	// ···
    });

存取账号的自定义数据

具体开发实例如下:

  1. 准备参数,指定账号名和自定义键值。

    let name: string = 'ZhangSan';
    let key: string = 'age';
    let value: string = '12';
  1. 调用setCustomData接口,设置账号的自定义数据。

    await appAccountManager.setCustomData(name, key, value).then(() => {
      console.info('setCustomData successfully');
    }).catch((err: BusinessError) => {
      console.error(`setCustomData failed: code is ${err.code}, message is ${err.message}`);
	// ···
    });
  1. 调用getCustomData接口,获取账号的自定义数据。

    appAccountManager.getCustomData(name, key).then((data: string) => {
      console.info('getCustomData successfully, data: ' + data);
	// ···
    }).catch((err: BusinessError) => {
      console.error(`getCustomData failed, code is ${err.code}, message is ${err.message}`);
	// ···
    });

存取账号的授权令牌

具体开发实例如下:

  1. 准备参数,指定账号名、账号所有者、授权类型和授权令牌。

    let name: string = 'ZhangSan';
    let owner: string = 'com.samples.managerapplicationaccount';
    let authType: string = 'getSocialData';
    let token: string = 'xxxxxx';
  1. 调用setAuthToken接口,设置指定授权类型的授权令牌。

    await appAccountManager.setAuthToken(name, authType, token).then(() => {
      console.info('setAuthToken successfully');
    }).catch((err: BusinessError) => {
      console.error(`setAuthToken failed: code is ${err.code}, message is ${err.message}`);
	// ···
    });
  1. 调用getAuthToken接口,获取指定授权类型的授权令牌。

    await appAccountManager.getAuthToken(name, owner, authType).then((data: string) => {
      console.info('getAuthToken successfully, data: ' + data);
	// ···
    }).catch((err: BusinessError) => {
      console.error(`getAuthToken failed, code is ${err.code}, message is ${err.message}`);
	// ···
    });

删除应用账号

用户退出登录后,应用需及时将相应的应用账号从系统中删除。

具体开发实例如下:

指定要删除的账号名称,调用removeAccount接口删除账号。

    let name: string = 'ZhangSan';
    appAccountManager.removeAccount(name).then(() => {
      console.info('removeAccount successfully');
	// ···
    }).catch((err: BusinessError) => {
      console.error(`removeAccount failed, code is ${err.code}, message is ${err.message}`);
	// ···
    });