• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# @ohos.account.osAccount (系统账号管理)(系统接口)
2
3<!--Kit: Basic Services Kit-->
4<!--Subsystem: Account-->
5<!--Owner: @steven-q-->
6<!--Designer: @JiDong-CS1-->
7<!--Tester: @zhaimengchao-->
8<!--Adviser: @zengyawen-->
9
10本模块提供管理系统账号的基础能力,包括系统账号的添加、删除、查询、设置、订阅、启动等功能。
11
12> **说明:**
13>
14> - 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
15> - 当前页面仅包含本模块的系统接口,其他公开接口参见[ohos.account.osAccount (系统账号管理)](js-apis-osAccount.md)。
16
17## 导入模块
18
19```ts
20import { osAccount } from '@kit.BasicServicesKit';
21```
22
23## AccountManager
24
25系统账号管理类。
26
27### activateOsAccount
28
29activateOsAccount(localId: number, callback: AsyncCallback&lt;void&gt;): void
30
31激活指定系统账号。使用callback异步回调。
32
33**系统接口:** 此接口为系统接口。
34
35**需要权限:** ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
36
37**系统能力:** SystemCapability.Account.OsAccount
38
39**参数:**
40
41| 参数名   | 类型                       | 必填 | 说明                                                |
42| -------- | ------------------------- | ---- | -------------------------------------------------- |
43| localId  | number                    | 是   | 系统账号ID。                  |
44| callback | AsyncCallback&lt;void&gt; | 是   | 回调函数。当账号激活成功时,err为null,否则为错误对象。 |
45
46**错误码:**
47
48| 错误码ID | 错误信息             |
49| -------- | ------------------- |
50| 201 | Permission denied.|
51| 202 | Not system application.|
52| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
53| 12300001 | The system service works abnormally. |
54| 12300002 | Invalid localId.    |
55| 12300003 | Account not found. |
56| 12300008 | Restricted Account. |
57| 12300010 | Service busy. Possible causes: The target account is being operated. |
58| 12300016 | The number of logged in accounts reaches the upper limit. |
59
60**示例:** 激活ID为100的系统账号
61  ```ts
62  import { BusinessError } from '@kit.BasicServicesKit';
63  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
64  let localId: number = 100;
65  try {
66    accountManager.activateOsAccount(localId, (err: BusinessError)=>{
67      if (err) {
68        console.error(`activateOsAccount failed, code is ${err.code}, message is ${err.message}`);
69      } else {
70        console.info('activateOsAccount successfully');
71      }
72    });
73  } catch (err) {
74    const err = err as BusinessError;
75    console.error(`activateOsAccount failed, code is ${err.code}, message is ${err.message}`);
76  }
77  ```
78
79### activateOsAccount
80
81activateOsAccount(localId: number): Promise&lt;void&gt;
82
83激活指定系统账号。使用Promise异步回调。
84
85**系统接口:** 此接口为系统接口。
86
87**需要权限:** ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
88
89**系统能力:** SystemCapability.Account.OsAccount
90
91**参数:**
92
93| 参数名  | 类型   | 必填 | 说明                 |
94| ------- | ------ | ---- | -------------------- |
95| localId | number | 是   | 系统账号ID。 |
96
97**返回值:**
98
99| 类型                | 说明                                  |
100| ------------------- | ------------------------------------ |
101| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
102
103**错误码:**
104
105| 错误码ID | 错误信息             |
106| -------- | ------------------- |
107| 201 | Permission denied.|
108| 202 | Not system application.|
109| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
110| 12300001 | The system service works abnormally. |
111| 12300002 | Invalid localId.    |
112| 12300003 | Account not found. |
113| 12300008 | Restricted Account. |
114| 12300010 | Service busy. Possible causes: The target account is being operated. |
115| 12300016 | The number of logged in accounts reaches the upper limit. |
116
117**示例:** 激活ID为100的系统账号
118  ```ts
119  import { BusinessError } from '@kit.BasicServicesKit';
120  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
121  let localId: number = 100;
122  try {
123    accountManager.activateOsAccount(localId).then(() => {
124      console.info('activateOsAccount successfully');
125    }).catch((err: BusinessError) => {
126      console.error(`activateOsAccount failed, code is ${err.code}, message is ${err.message}`);
127    });
128  } catch (e) {
129    const err = e as BusinessError;
130    console.error(`activateOsAccount exception: code is ${err.code}, message is ${err.message}`);
131  }
132  ```
133
134### deactivateOsAccount<sup>12+</sup>
135
136deactivateOsAccount(localId: number): Promise&lt;void&gt;
137
138注销(退出登录)指定系统账号。使用Promise异步回调。
139
140**系统接口:** 此接口为系统接口。
141
142**需要权限:** ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
143
144**系统能力:** SystemCapability.Account.OsAccount
145
146**参数:**
147
148| 参数名  | 类型   | 必填 | 说明                 |
149| ------- | ------ | ---- | -------------------- |
150| localId | number | 是   | 系统账号ID。 |
151
152**返回值:**
153
154| 类型                | 说明                                  |
155| ------------------- | ------------------------------------ |
156| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
157
158**错误码:**
159
160| 错误码ID | 错误信息             |
161| -------- | ------------------- |
162| 201 | Permission denied.|
163| 202 | Not system application.|
164| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
165| 12300001 | The system service works abnormally. |
166| 12300003 | Account not found. |
167| 12300008 | Restricted Account. |
168| 12300010 | Service busy. Possible causes: The target account is being operated. |
169
170**示例:** 注销ID为100的系统账号
171  ```ts
172  import { BusinessError } from '@kit.BasicServicesKit';
173  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
174  let localId: number = 100;
175  try {
176    accountManager.deactivateOsAccount(localId).then(() => {
177      console.info('deactivateOsAccount successfully');
178    }).catch((err: BusinessError) => {
179      console.error(`deactivateOsAccount failed, code is ${err.code}, message is ${err.message}`);
180    });
181  } catch (e) {
182    const err = e as BusinessError;
183    console.error(`deactivateOsAccount exception: code is ${err.code}, message is ${err.message}`);
184  }
185  ```
186
187### isOsAccountActivated<sup>11+</sup>
188
189isOsAccountActivated(localId: number): Promise&lt;boolean&gt;
190
191判断指定系统账号是否处于激活状态。使用Promise异步回调。
192
193**系统接口:** 此接口为系统接口。
194
195**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
196
197**系统能力:** SystemCapability.Account.OsAccount
198
199**参数:**
200
201| 参数名  | 类型   | 必填 | 说明                               |
202| ------- | ------ | ---- | --------------------------------- |
203| localId | number | 是   | 系统账号ID。 |
204
205**返回值:**
206
207| 类型                   | 说明                                                       |
208| ---------------------- | ---------------------------------------------------------- |
209| Promise&lt;boolean&gt; | Promise对象。返回true表示账号已激活;返回false表示账号未激活。 |
210
211**错误码:**
212
213| 错误码ID | 错误信息             |
214| -------- | ------------------- |
215| 201 | Permission denied.|
216| 202 | Not system application.|
217| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
218| 12300001 | The system service works abnormally. |
219| 12300003 | Account not found. |
220
221**示例:** 判断ID为100的系统账号是否处于激活状态
222
223  ```ts
224  import { BusinessError } from '@kit.BasicServicesKit';
225  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
226  let localId: number = 100;
227  try {
228    accountManager.isOsAccountActivated(localId).then((isActivated: boolean) => {
229      console.info('isOsAccountActivated successfully, isActivated: ' + isActivated);
230    }).catch((err: BusinessError) => {
231      console.error(`isOsAccountActivated failed, code is ${err.code}, message is ${err.message}`);
232    });
233  } catch (err) {
234    const err = err as BusinessError;
235    console.error(`isOsAccountActivated exception: code is ${err.code}, message is ${err.message}`);
236  }
237  ```
238
239### isOsAccountConstraintEnabled<sup>11+</sup>
240
241isOsAccountConstraintEnabled(localId: number, constraint: string): Promise&lt;boolean&gt;
242
243判断指定系统账号是否使能指定约束。使用Promise异步回调。
244
245**系统接口:** 此接口为系统接口。
246
247**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
248
249**系统能力:** SystemCapability.Account.OsAccount
250
251**参数:**
252
253| 参数名     | 类型   | 必填 | 说明                                |
254| ---------- | ------ | ---- | ---------------------------------- |
255| localId    | number | 是   | 系统账号ID。  |
256| constraint | string | 是   | 指定的[约束](js-apis-osAccount.md#系统账号约束列表)名称。 |
257
258**返回值:**
259
260| 类型                   | 说明                                                                  |
261| --------------------- | --------------------------------------------------------------------- |
262| Promise&lt;boolean&gt; | Promise对象。返回true表示已使能指定的约束;返回false表示未使能指定的约束。 |
263
264**错误码:**
265
266| 错误码ID | 错误信息             |
267| -------- | ------------------- |
268| 201 | Permission denied.|
269| 202 | Not system application.|
270| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
271| 12300001 | The system service works abnormally. |
272| 12300003 | Account not found. |
273
274**示例:** 判断ID为100的系统账号是否有禁止使用Wi-Fi的约束
275
276  ```ts
277  import { BusinessError } from '@kit.BasicServicesKit';
278  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
279  let localId: number = 100;
280  let constraint: string = 'constraint.wifi';
281  try {
282    accountManager.isOsAccountConstraintEnabled(localId, constraint).then((isEnabled: boolean) => {
283      console.info('isOsAccountConstraintEnabled successfully, isEnabled: ' + isEnabled);
284    }).catch((err: BusinessError) => {
285      console.error(`isOsAccountConstraintEnabled failed, code is ${err.code}, message is ${err.message}`);
286    });
287  } catch (err) {
288    const err = err as BusinessError;
289    console.error(`isOsAccountConstraintEnabled exception: code is ${err.code}, message is ${err.message}`);
290  }
291  ```
292
293### isOsAccountUnlocked<sup>11+</sup>
294
295isOsAccountUnlocked(localId: number): Promise&lt;boolean&gt;
296
297检查指定系统账号是否已验证。使用Promise异步回调。
298
299**系统接口:** 此接口为系统接口。
300
301**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
302
303**系统能力:** SystemCapability.Account.OsAccount
304
305**参数:**
306
307| 参数名  | 类型   | 必填 | 说明                                                              |
308| ------- | ------ | ---- | --------------------------------------------------------------- |
309| localId | number | 是   | 系统账号ID。不填则检查当前系统账号是否已验证。 |
310
311**返回值:**
312
313| 类型                   | 说明                                                               |
314| ---------------------- | ----------------------------------------------------------------- |
315| Promise&lt;boolean&gt; | Promise对象。返回true表示当前账号已认证解锁;返回false表示当前账号未认证解锁。 |
316
317**错误码:**
318
319| 错误码ID | 错误信息             |
320| -------- | ------------------- |
321| 201 | Permission denied.|
322| 202 | Not system application.|
323| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
324| 12300001 | The system service works abnormally. |
325| 12300003 | Account not found. |
326
327**示例:**
328
329  ```ts
330  import { BusinessError } from '@kit.BasicServicesKit';
331  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
332  let localId: number = 100;
333  try {
334    accountManager.isOsAccountUnlocked(localId).then((isVerified: boolean) => {
335      console.info('isOsAccountUnlocked successfully, isVerified: ' + isVerified);
336    }).catch((err: BusinessError) => {
337      console.error(`isOsAccountUnlocked failed, code is ${err.code}, message is ${err.message}`);
338    });
339  } catch (err) {
340    const err = err as BusinessError;
341    console.error(`isOsAccountUnlocked exception: code is ${err.code}, message is ${err.message}`);
342  }
343  ```
344
345### removeOsAccount
346
347removeOsAccount(localId: number, callback: AsyncCallback&lt;void&gt;): void
348
349删除指定系统账号。使用callback异步回调。
350
351**系统接口:** 此接口为系统接口。
352
353**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
354
355**系统能力:** SystemCapability.Account.OsAccount
356
357**参数:**
358
359| 参数名   | 类型                      | 必填 | 说明                                                 |
360| -------- | ------------------------- | ---- | -------------------------------------------------- |
361| localId  | number                    | 是   | 系统账号ID。                  |
362| callback | AsyncCallback&lt;void&gt; | 是   | 回调函数。如果删除账号成功,err为null,否则为错误对象。 |
363
364**错误码:**
365
366| 错误码ID | 错误信息             |
367| -------- | ------------------- |
368| 201 | Permission denied.|
369| 202 | Not system application.|
370| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
371| 12300001 | The system service works abnormally. |
372| 12300002 | Invalid localId.    |
373| 12300003 | Account not found. |
374| 12300008 | Restricted Account. |
375| 12300010 | Service busy. Possible causes: The target account is being operated. |
376
377**示例:**
378
379  ```ts
380  import { BusinessError } from '@kit.BasicServicesKit';
381  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
382  let accountName: string = 'testAccountName';
383  try {
384    accountManager.createOsAccount(accountName, osAccount.OsAccountType.NORMAL,
385      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo) => {
386        accountManager.removeOsAccount(osAccountInfo.localId, (err: BusinessError)=>{
387          if (err) {
388            console.error(`removeOsAccount failed, code is ${err.code}, message is ${err.message}`);
389          } else {
390            console.info('removeOsAccount successfully');
391          }
392      });
393    });
394  } catch (err) {
395    const err = err as BusinessError;
396    console.error(`removeOsAccount exception: code is ${err.code}, message is ${err.message}`);
397  }
398  ```
399
400### removeOsAccount
401
402removeOsAccount(localId: number): Promise&lt;void&gt;
403
404删除指定系统账号。使用Promise异步回调。
405
406**系统接口:** 此接口为系统接口。
407
408**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
409
410**系统能力:** SystemCapability.Account.OsAccount
411
412**参数:**
413
414| 参数名  | 类型   | 必填 | 说明                               |
415| ------- | ------ | ---- | --------------------------------- |
416| localId | number | 是   | 系统账号ID。 |
417
418**返回值:**
419
420| 类型                | 说明                                  |
421| ------------------- | ------------------------------------ |
422| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
423
424**错误码:**
425
426| 错误码ID | 错误信息             |
427| -------- | ------------------- |
428| 201 | Permission denied.|
429| 202 | Not system application.|
430| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
431| 12300001 | The system service works abnormally. |
432| 12300002 | Invalid localId.    |
433| 12300003 | Account not found. |
434| 12300008 | Restricted Account. |
435| 12300010 | Service busy. Possible causes: The target account is being operated. |
436
437**示例:**
438
439  ```ts
440  import { BusinessError } from '@kit.BasicServicesKit';
441  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
442  let accountName: string = 'testAccountName';
443  try {
444    accountManager.createOsAccount(accountName, osAccount.OsAccountType.NORMAL,
445      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo)=>{
446        accountManager.removeOsAccount(osAccountInfo.localId).then(() => {
447          console.info('removeOsAccount successfully');
448        }).catch((err: BusinessError) => {
449            console.error(`removeOsAccount failed, code is ${err.code}, message is ${err.message}`);
450        });
451    });
452  } catch (err) {
453    const err = err as BusinessError;
454    console.error(`removeOsAccount exception: code is ${err.code}, message is ${err.message}`);
455  }
456  ```
457
458### setOsAccountConstraints
459
460setOsAccountConstraints(localId: number, constraints: Array&lt;string&gt;, enable: boolean,callback: AsyncCallback&lt;void&gt;): void
461
462为指定系统账号设置/删除约束。使用callback异步回调。
463
464**系统接口:** 此接口为系统接口。
465
466**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
467
468**系统能力:** SystemCapability.Account.OsAccount
469
470**参数:**
471
472| 参数名      | 类型                      | 必填 | 说明                                             |
473| ----------- | ------------------------- | ---- | ----------------------------------------------- |
474| localId     | number                    | 是   | 系统账号ID。               |
475| constraints | Array&lt;string&gt;       | 是   | 待设置/删除的[约束](js-apis-osAccount.md#系统账号约束列表)列表。        |
476| enable      | boolean                   | 是   | 设置(true)/删除(false) 。                          |
477| callback    | AsyncCallback&lt;void&gt; | 是   | 回调函数。如果设置成功,err为null,否则为错误对象。 |
478
479**错误码:**
480
481| 错误码ID | 错误信息             |
482| -------- | ------------------- |
483| 201 | Permission denied.|
484| 202 | Not system application.|
485| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
486| 12300001 | The system service works abnormally. |
487| 12300002 | Invalid localId or constraints.    |
488| 12300003 | Account not found. |
489| 12300008 | Restricted Account. |
490
491**示例:** 给ID为100的系统账号设置禁止使用Wi-Fi的约束
492
493  ```ts
494  import { BusinessError } from '@kit.BasicServicesKit';
495  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
496  let localId: number = 100;
497  let constraint: string = 'constraint.wifi';
498  try {
499    accountManager.setOsAccountConstraints(localId, [constraint], true, (err: BusinessError) => {
500      if (err) {
501        console.error(`setOsAccountConstraints failed, code is ${err.code}, message is ${err.message}`);
502      } else {
503        console.info('setOsAccountConstraints successfully');
504      }
505    });
506  } catch (err) {
507    const err = err as BusinessError;
508    console.error(`setOsAccountConstraints exception: code is ${err.code}, message is ${err.message}`);
509  }
510  ```
511
512### setOsAccountConstraints
513
514setOsAccountConstraints(localId: number, constraints: Array&lt;string&gt;, enable: boolean): Promise&lt;void&gt;
515
516为指定系统账号设置/删除约束。使用Promise异步回调。
517
518**系统接口:** 此接口为系统接口。
519
520**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
521
522**系统能力:** SystemCapability.Account.OsAccount
523
524**参数:**
525
526| 参数名      | 类型                | 必填 | 说明                                         |
527| ----------- | ------------------- | ---- | -------------------------------------------- |
528| localId     | number              | 是   | 系统账号ID。           |
529| constraints | Array&lt;string&gt; | 是   | 待设置/删除的[约束](js-apis-osAccount.md#系统账号约束列表)列表。    |
530| enable      | boolean             | 是   | 设置(true)/删除(false)。                     |
531
532**返回值:**
533
534| 类型                | 说明                                 |
535| :------------------ | :----------------------------------- |
536| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
537
538**错误码:**
539
540| 错误码ID | 错误信息             |
541| -------- | ------------------- |
542| 201 | Permission denied.|
543| 202 | Not system application.|
544| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
545| 12300001 | The system service works abnormally. |
546| 12300002 | Invalid localId or constraints.    |
547| 12300003 | Account not found. |
548| 12300008 | Restricted Account. |
549
550**示例:** 删除ID为100的系统账号的禁止使用Wi-Fi的约束
551
552  ```ts
553  import { BusinessError } from '@kit.BasicServicesKit';
554  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
555  let localId: number = 100;
556  try {
557    accountManager.setOsAccountConstraints(localId, ['constraint.location.set'], false).then(() => {
558      console.info('setOsAccountConstraints successfully');
559    }).catch((err: BusinessError) => {
560      console.error(`setOsAccountConstraints failed, code is ${err.code}, message is ${err.message}`);
561    });
562  } catch (err) {
563    const err = err as BusinessError;
564    console.error(`setOsAccountConstraints exception: code is ${err.code}, message is ${err.message}`);
565  }
566  ```
567
568### setOsAccountName
569
570setOsAccountName(localId: number, localName: string, callback: AsyncCallback&lt;void&gt;): void
571
572设置指定系统账号的账号名。使用callback异步回调。
573
574**系统接口:** 此接口为系统接口。
575
576**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
577
578**系统能力:** SystemCapability.Account.OsAccount
579
580**参数:**
581
582| 参数名    | 类型                      | 必填 | 说明                                             |
583| :-------- | ------------------------- | ---- | ----------------------------------------------- |
584| localId   | number                    | 是   | 系统账号ID。               |
585| localName | string                    | 是   | 账号名,最大长度为1024个字符。                          |
586| callback  | AsyncCallback&lt;void&gt; | 是   | 回调函数。如果设置成功,err为null,否则为错误对象。 |
587
588**错误码:**
589
590| 错误码ID | 错误信息             |
591| -------- | ------------------- |
592| 201 | Permission denied.|
593| 202 | Not system application.|
594| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
595| 12300001 | The system service works abnormally. |
596| 12300002 | Invalid localId or localName. |
597| 12300003 | Account not found. |
598| 12300008 | Restricted Account. |
599
600**示例:** 将ID为100的系统账号的账号名设置成demoName
601
602  ```ts
603  import { BusinessError } from '@kit.BasicServicesKit';
604  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
605  let localId: number = 100;
606  let name: string = 'demoName';
607  try {
608    accountManager.setOsAccountName(localId, name, (err: BusinessError) => {
609      if (err) {
610        console.error(`setOsAccountName failed, code is ${err.code}, message is ${err.message}`);
611      } else {
612        console.info('setOsAccountName successfully');
613      }
614    });
615  } catch (err) {
616    const err = err as BusinessError;
617    console.error(`setOsAccountName exception: code is ${err.code}, message is ${err.message}`);
618  }
619  ```
620
621### setOsAccountName
622
623setOsAccountName(localId: number, localName: string): Promise&lt;void&gt;
624
625设置指定系统账号的账号名。使用Promise异步调用。
626
627**系统接口:** 此接口为系统接口。
628
629**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
630
631**系统能力:** SystemCapability.Account.OsAccount
632
633**参数:**
634
635| 参数名    | 类型   | 必填 | 说明                                |
636| --------- | ------ | ---- | --------------------------------- |
637| localId   | number | 是   | 系统账号ID。 |
638| localName | string | 是   | 账号名,最大长度为1024个字符。            |
639
640**返回值:**
641
642| 类型                | 说明                                  |
643| ------------------- | ------------------------------------ |
644| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
645
646**错误码:**
647
648| 错误码ID | 错误信息             |
649| -------- | ------------------- |
650| 201 | Permission denied.|
651| 202 | Not system application.|
652| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
653| 12300001 | The system service works abnormally. |
654| 12300002 | Invalid localId or localName.    |
655| 12300003 | Account not found. |
656| 12300008 | Restricted Account. |
657
658**示例:** 将ID为100的系统账号的账号名设置成demoName
659
660  ```ts
661  import { BusinessError } from '@kit.BasicServicesKit';
662  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
663  let localId: number = 100;
664  let name: string = 'testName';
665  try {
666    accountManager.setOsAccountName(localId, name).then(() => {
667      console.info('setOsAccountName successfully');
668    }).catch((err: BusinessError) => {
669      console.error(`setOsAccountName failed, code is ${err.code}, message is ${err.message}`);
670    });
671  } catch (err) {
672    const err = err as BusinessError;
673    console.error(`setOsAccountName exception: code is ${err.code}, message is ${err.message}`);
674  }
675  ```
676
677### queryMaxOsAccountNumber
678
679queryMaxOsAccountNumber(callback: AsyncCallback&lt;number&gt;): void
680
681查询允许创建的系统账号的最大数量。使用callback异步回调。
682
683**系统接口:** 此接口为系统接口。
684
685**系统能力:** SystemCapability.Account.OsAccount
686
687**参数:**
688
689| 参数名   | 类型                        | 必填 | 说明                                                                              |
690| -------- | --------------------------- | ---- | -------------------------------------------------------------------------------- |
691| callback | AsyncCallback&lt;number&gt; | 是   | 回调函数,如果查询成功,err为null,data为允许创建的系统账号的最大数量;否则为错误对象。 |
692
693**错误码:**
694
695| 错误码ID | 错误信息       |
696| -------- | ------------- |
697| 202 | Not system application.|
698| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
699| 12300001 | The system service works abnormally. |
700
701**示例:**
702
703  ```ts
704  import { BusinessError } from '@kit.BasicServicesKit';
705  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
706  try {
707    accountManager.queryMaxOsAccountNumber((err: BusinessError, maxCnt: number) => {
708      if (err) {
709        console.error(`queryMaxOsAccountNumber failed, code is ${err.code}, message is ${err.message}`);
710      } else {
711        console.info('queryMaxOsAccountNumber successfully, maxCnt:' + maxCnt);
712      }
713    });
714  } catch (err) {
715    const err = err as BusinessError;
716    console.error(`queryMaxOsAccountNumber exception: code is ${err.code}, message is ${err.message}`);
717  }
718  ```
719
720### queryMaxOsAccountNumber
721
722queryMaxOsAccountNumber(): Promise&lt;number&gt;
723
724查询允许创建的系统账号的最大数量。使用Promise异步回调。
725
726**系统接口:** 此接口为系统接口。
727
728**系统能力:** SystemCapability.Account.OsAccount
729
730**返回值:**
731
732| 类型                  | 说明                                         |
733| --------------------- | ------------------------------------------- |
734| Promise&lt;number&gt; | Promise对象,返回允许创建的系统账号的最大数量。 |
735
736**错误码:**
737
738| 错误码ID | 错误信息       |
739| -------- | ------------- |
740| 202 | Not system application.|
741| 12300001 | The system service works abnormally. |
742
743**示例:**
744
745  ```ts
746  import { BusinessError } from '@kit.BasicServicesKit';
747  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
748  try {
749    accountManager.queryMaxOsAccountNumber().then((maxCnt: number) => {
750      console.info('queryMaxOsAccountNumber successfully, maxCnt: ' + maxCnt);
751    }).catch((err: BusinessError) => {
752      console.error(`queryMaxOsAccountNumber failed, code is ${err.code}, message is ${err.message}`);
753    });
754  } catch (err) {
755    const err = err as BusinessError;
756    console.error(`queryMaxOsAccountNumber exception: code is ${err.code}, message is ${err.message}`);
757  }
758  ```
759
760### queryMaxLoggedInOsAccountNumber<sup>12+</sup>
761
762queryMaxLoggedInOsAccountNumber(): Promise&lt;number&gt;
763
764查询允许同时登录的系统账号的最大数量。使用Promise异步回调。
765
766**系统接口:** 此接口为系统接口。
767
768**系统能力:** SystemCapability.Account.OsAccount
769
770**返回值:**
771
772| 类型                  | 说明                                         |
773| --------------------- | ------------------------------------------- |
774| Promise&lt;number&gt; | Promise对象,返回允许登录的系统账号的最大数量。 |
775
776**错误码:**
777
778| 错误码ID | 错误信息       |
779| -------- | ------------- |
780| 202 | Not system application.|
781| 12300001 | The system service works abnormally. |
782
783**示例:**
784
785  ```ts
786  import { BusinessError } from '@kit.BasicServicesKit';
787  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
788  try {
789    accountManager.queryMaxLoggedInOsAccountNumber().then((maxNum: number) => {
790      console.info('queryMaxLoggedInOsAccountNumber successfully, maxNum: ' + maxNum);
791    }).catch((err: BusinessError) => {
792      console.error(`queryMaxLoggedInOsAccountNumber failed, code is ${err.code}, message is ${err.message}`);
793    });
794  } catch (err) {
795    const err = err as BusinessError;
796    console.error(`queryMaxLoggedInOsAccountNumber exception: code is ${err.code}, message is ${err.message}`);
797  }
798  ```
799
800### getEnabledOsAccountConstraints<sup>11+</sup>
801
802getEnabledOsAccountConstraints(localId: number): Promise&lt;Array&lt;string&gt;&gt;
803
804获取指定系统账号已使能的全部约束。使用Promise异步回调。
805
806**系统接口:** 此接口为系统接口。
807
808**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
809
810**系统能力:** SystemCapability.Account.OsAccount
811
812**参数:**
813
814| 参数名  | 类型   | 必填 | 说明         |
815| ------- | ------ | ---- | ------------ |
816| localId | number | 是   | 系统账号ID。 |
817
818**返回值:**
819
820| 类型                               | 说明                                                       |
821| ---------------------------------- | ---------------------------------------------------------- |
822| Promise&lt;Array&lt;string&gt;&gt; | Promise对象,返回指定系统账号已使能的全部[约束](js-apis-osAccount.md#系统账号约束列表)。 |
823
824**错误码:**
825
826| 错误码ID | 错误信息             |
827| -------- | ------------------- |
828| 201 | Permission denied.|
829| 202 | Not system application.|
830| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
831| 12300001 | The system service works abnormally. |
832| 12300003 | Account not found. |
833
834**示例:** 获取ID为100的系统账号的全部约束
835
836  ```ts
837  import { BusinessError } from '@kit.BasicServicesKit';
838  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
839  let localId: number = 100;
840  try {
841    accountManager.getEnabledOsAccountConstraints(localId).then((constraints: string[]) => {
842      console.info('getEnabledOsAccountConstraints, constraints: ' + constraints);
843    }).catch((err: BusinessError) => {
844      console.error(`getEnabledOsAccountConstraints err: code is ${err.code}, message is ${err.message}`);
845    });
846  } catch (e) {
847    const err = e as BusinessError;
848    console.error(`getEnabledOsAccountConstraints exception: code is ${err.code}, message is ${err.message}`);
849  }
850  ```
851
852### queryAllCreatedOsAccounts
853
854queryAllCreatedOsAccounts(callback: AsyncCallback&lt;Array&lt;OsAccountInfo&gt;&gt;): void
855
856查询已创建的所有系统账号的信息列表。使用callback异步回调。
857
858**系统接口:** 此接口为系统接口。
859
860**系统能力:** SystemCapability.Account.OsAccount
861
862**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
863
864**参数:**
865
866| 参数名   | 类型                                                         | 必填 | 说明                                               |
867| -------- | ------------------------------------------------------------ | ---- | -------------------------------------------------- |
868| callback | AsyncCallback&lt;Array&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt;&gt; | 是   | 回调函数。如果查询成功,err为null,data为已创建的所有系统账号的信息列表;否则为错误对象。 |
869
870**错误码:**
871
872| 错误码ID | 错误信息       |
873| -------- | ------------- |
874| 201 | Permission denied.|
875| 202 | Not system application.|
876| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types.|
877| 12300001 | The system service works abnormally. |
878
879**示例:**
880
881  ```ts
882  import { BusinessError } from '@kit.BasicServicesKit';
883  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
884  try {
885    accountManager.queryAllCreatedOsAccounts((err: BusinessError, accountArr: osAccount.OsAccountInfo[])=>{
886      if (err) {
887        console.error(`queryAllCreatedOsAccounts exception:code is ${err.code}, message is ${err.message}`);
888      } else {
889        console.info('queryAllCreatedOsAccounts accountArr:' + JSON.stringify(accountArr));
890      }
891    });
892  } catch (e) {
893    const err = e as BusinessError;
894    console.error(`queryAllCreatedOsAccounts exception: code is ${err.code}, message is ${err.message}`);
895  }
896  ```
897
898### queryAllCreatedOsAccounts
899
900queryAllCreatedOsAccounts(): Promise&lt;Array&lt;OsAccountInfo&gt;&gt;
901
902查询已创建的所有系统账号的信息列表。使用Promise异步回调。
903
904**系统接口:** 此接口为系统接口。
905
906**系统能力:** SystemCapability.Account.OsAccount
907
908**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
909
910**返回值:**
911
912| 类型                                                        | 说明                                           |
913| ----------------------------------------------------------- | --------------------------------------------- |
914| Promise&lt;Array&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt;&gt; | Promise对象,返回已创建的所有系统账号的信息列表。 |
915
916**错误码:**
917
918| 错误码ID | 错误信息       |
919| -------- | ------------- |
920| 201 | Permission denied.|
921| 202 | Not system application.|
922| 12300001 | The system service works abnormally. |
923
924**示例:**
925
926  ```ts
927  import { BusinessError } from '@kit.BasicServicesKit';
928  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
929  try {
930    accountManager.queryAllCreatedOsAccounts().then((accountArr: osAccount.OsAccountInfo[]) => {
931      console.info('queryAllCreatedOsAccounts, accountArr: ' + JSON.stringify(accountArr));
932    }).catch((err: BusinessError) => {
933      console.error(`queryAllCreatedOsAccounts err: code is ${err.code}, message is ${err.message}`);
934    });
935  } catch (e) {
936    const err = e as BusinessError;
937    console.error(`queryAllCreatedOsAccounts exception: code is ${err.code}, message is ${err.message}`);
938  }
939  ```
940
941### createOsAccount
942
943createOsAccount(localName: string, type: OsAccountType, callback: AsyncCallback&lt;OsAccountInfo&gt;): void
944
945创建一个系统账号。使用callback异步回调。
946
947**系统接口:** 此接口为系统接口。
948
949**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
950
951**系统能力:** SystemCapability.Account.OsAccount
952
953**参数:**
954
955| 参数名    | 类型                                                 | 必填 | 说明                                                                         |
956| :-------- | ---------------------------------------------------- | ---- | --------------------------------------------------------------------------- |
957| localName | string                                               | 是   | 创建的系统账号的名称。                                                        |
958| type      | [OsAccountType](js-apis-osAccount.md#osaccounttype)                      | 是   | 创建的系统账号的类型。                                                        |
959| callback  | AsyncCallback&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | 是   | 回调函数。如果创建成功,err为null,data为新创建的系统账号的信息;否则为错误对象。 |
960
961**错误码:**
962
963| 错误码ID  | 错误信息                   |
964| -------- | ------------------------- |
965| 201 | Permission denied.|
966| 202 | Not system application.|
967| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
968| 12300001 | The system service works abnormally. |
969| 12300002 | Invalid localName or type. |
970| 12300004 | Local name already exists. |
971| 12300005 | Multi-user not supported. |
972| 12300006 | Unsupported account type. |
973| 12300007 | The number of accounts has reached the upper limit. |
974
975**示例:**
976
977  ```ts
978  import { BusinessError } from '@kit.BasicServicesKit';
979  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
980  try {
981    accountManager.createOsAccount('testName', osAccount.OsAccountType.NORMAL,
982      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo)=>{
983      if (err) {
984        console.error(`createOsAccount exception:code is ${err.code}, message is ${err.message}`);
985      } else {
986        console.info('createOsAccount osAccountInfo:' + JSON.stringify(osAccountInfo));
987      }
988    });
989  } catch (e) {
990    const err = e as BusinessError;
991    console.error(`createOsAccount exception: code is ${err.code}, message is ${err.message}`);
992  }
993  ```
994
995### createOsAccount
996
997createOsAccount(localName: string, type: OsAccountType, options?: CreateOsAccountOptions): Promise&lt;OsAccountInfo&gt;
998
999创建一个系统账号。使用Promise异步回调。
1000
1001**系统接口:** 此接口为系统接口。
1002
1003**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1004
1005**系统能力:** SystemCapability.Account.OsAccount
1006
1007**参数:**
1008
1009| 参数名    | 类型                            | 必填 | 说明                   |
1010| --------- | ------------------------------- | ---- | ---------------------- |
1011| localName | string                          | 是   | 创建的系统账号的名称。 |
1012| type      | [OsAccountType](js-apis-osAccount.md#osaccounttype) | 是   | 创建的系统账号的类型。 |
1013| options      | [CreateOsAccountOptions](#createosaccountoptions12) | 否   | 创建系统账号的选项,默认为空。<br/>从API version 12开始支持该可选参数。|
1014
1015**返回值:**
1016
1017| 类型                                           | 说明                                  |
1018| ---------------------------------------------- | ------------------------------------- |
1019| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise对象,返回新创建的系统账号的信息。 |
1020
1021**错误码:**
1022
1023| 错误码ID  | 错误信息                   |
1024| -------- | ------------------------- |
1025| 201 | Permission denied.|
1026| 202 | Not system application.|
1027| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1028| 12300001 | The system service works abnormally. |
1029| 12300002 | Invalid localName, type or options. |
1030| 12300004 | Local name already exists. |
1031| 12300005 | Multi-user not supported. |
1032| 12300006 | Unsupported account type. |
1033| 12300007 | The number of accounts has reached the upper limit. |
1034| 12300015 | The short name already exists. |
1035
1036**示例:**
1037
1038  ```ts
1039  import { BusinessError } from '@kit.BasicServicesKit';
1040  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1041  let options: osAccount.CreateOsAccountOptions = {
1042    shortName: 'myShortName',
1043    disallowedPreinstalledBundles: [],
1044    allowedPreinstalledBundles: [],
1045  }
1046  try {
1047    accountManager.createOsAccount('testAccountName', osAccount.OsAccountType.NORMAL, options).then(
1048      (accountInfo: osAccount.OsAccountInfo) => {
1049      console.info('createOsAccount, accountInfo: ' + JSON.stringify(accountInfo));
1050    }).catch((err: BusinessError) => {
1051      console.error(`createOsAccount err: code is ${err.code}, message is ${err.message}`);
1052    });
1053  } catch (e) {
1054    const err = e as BusinessError;
1055    console.error(`createOsAccount exception: code is ${err.code}, message is ${err.message}`);
1056  }
1057  ```
1058
1059### createOsAccountForDomain<sup>8+</sup>
1060
1061createOsAccountForDomain(type: OsAccountType, domainInfo: DomainAccountInfo, callback: AsyncCallback&lt;OsAccountInfo&gt;): void
1062
1063根据域账号信息,创建一个系统账号并将其与域账号关联。使用callback异步回调。
1064
1065**系统接口:** 此接口为系统接口。
1066
1067**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1068
1069**系统能力:** SystemCapability.Account.OsAccount
1070
1071**参数:**
1072
1073| 参数名     | 类型                                                 | 必填 | 说明                                                                         |
1074| ---------- | ---------------------------------------------------- | ---- | -------------------------------------------------------------------------- |
1075| type       | [OsAccountType](js-apis-osAccount.md#osaccounttype)                      | 是   | 创建的系统账号的类型。                                                       |
1076| domainInfo | [DomainAccountInfo](#domainaccountinfo8)              | 是   | 域账号信息。                                                               |
1077| callback   | AsyncCallback&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | 是   | 回调函数。如果创建成功,err为null,data为新创建的系统账号的信息;否则为错误对象。 |
1078
1079**错误码:**
1080
1081| 错误码ID | 错误信息                     |
1082| -------- | ------------------- |
1083| 201 | Permission denied.|
1084| 202 | Not system application.|
1085| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1086| 801 | Capability not supported.|
1087| 12300001 | The system service works abnormally. |
1088| 12300002 | Invalid type or domainInfo. |
1089| 12300004 | Account already exists. |
1090| 12300005 | Multi-user not supported. |
1091| 12300006 | Unsupported account type. |
1092| 12300007 | The number of accounts has reached the upper limit. |
1093
1094**示例:**
1095
1096  ```ts
1097  import { BusinessError } from '@kit.BasicServicesKit';
1098  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1099  let domainInfo: osAccount.DomainAccountInfo =
1100    {domain: 'testDomain', accountName: 'testAccountName'};
1101  try {
1102    accountManager.createOsAccountForDomain(osAccount.OsAccountType.NORMAL, domainInfo,
1103      (err: BusinessError, osAccountInfo: osAccount.OsAccountInfo)=>{
1104      if (err) {
1105        console.error(`createOsAccountForDomain exception:code is ${err.code}, message is ${err.message}`);
1106      } else {
1107        console.info('createOsAccountForDomain osAccountInfo:' + JSON.stringify(osAccountInfo));
1108      }
1109    });
1110  } catch (e) {
1111    const err = e as BusinessError;
1112    console.error(`createOsAccountForDomain exception: code is ${err.code}, message is ${err.message}`);
1113  }
1114  ```
1115
1116### createOsAccountForDomain<sup>8+</sup>
1117
1118createOsAccountForDomain(type: OsAccountType, domainInfo: DomainAccountInfo, options?: CreateOsAccountForDomainOptions): Promise&lt;OsAccountInfo&gt;
1119
1120根据传入的域账号信息,创建与其关联的系统账号。使用Promise异步回调。
1121
1122**系统接口:** 此接口为系统接口。
1123
1124**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1125
1126**系统能力:** SystemCapability.Account.OsAccount
1127
1128**参数:**
1129
1130| 参数名     | 类型                                      | 必填 | 说明                 |
1131| ---------- | ---------------------------------------- | ---- | -------------------- |
1132| type       | [OsAccountType](js-apis-osAccount.md#osaccounttype)          | 是   | 创建的系统账号的类型。 |
1133| domainInfo | [DomainAccountInfo](#domainaccountinfo8) | 是   | 域账号信息。          |
1134| options      | [CreateOsAccountForDomainOptions](#createosaccountfordomainoptions12) | 否   | 创建账号的可选参数,默认为空。 <br/>从API version 12开始支持该可选参数。|
1135
1136**返回值:**
1137
1138| 类型                                           | 说明                                    |
1139| ---------------------------------------------- | -------------------------------------- |
1140| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise对象,返回新创建的系统账号的信息。 |
1141
1142**错误码:**
1143
1144| 错误码ID | 错误信息                     |
1145| -------- | ------------------- |
1146| 201 | Permission denied.|
1147| 202 | Not system application.|
1148| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1149| 801 | Capability not supported.|
1150| 12300001 | The system service works abnormally. |
1151| 12300002 | Invalid type, domainInfo or options. |
1152| 12300004 | Account already exists. |
1153| 12300005 | Multi-user not supported. |
1154| 12300006 | Unsupported account type. |
1155| 12300007 | The number of accounts has reached the upper limit. |
1156| 12300015 | The short name already exists. |
1157
1158**示例:**
1159
1160  ```ts
1161  import { BusinessError } from '@kit.BasicServicesKit';
1162  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1163  let domainInfo: osAccount.DomainAccountInfo =
1164    {domain: 'testDomain', accountName: 'testAccountName'};
1165  let options: osAccount.CreateOsAccountForDomainOptions = {
1166    shortName: 'myShortName'
1167  }
1168  try {
1169    accountManager.createOsAccountForDomain(osAccount.OsAccountType.NORMAL, domainInfo, options).then(
1170      (accountInfo: osAccount.OsAccountInfo) => {
1171      console.info('createOsAccountForDomain, account info: ' + JSON.stringify(accountInfo));
1172    }).catch((err: BusinessError) => {
1173      console.error(`createOsAccountForDomain err: code is ${err.code}, message is ${err.message}`);
1174    });
1175  } catch (e) {
1176    const err = e as BusinessError;
1177    console.error(`createOsAccountForDomain exception: code is ${err.code}, message is ${err.message}`);
1178  }
1179  ```
1180
1181### queryOsAccount<sup>11+</sup>
1182
1183queryOsAccount(): Promise&lt;OsAccountInfo&gt;
1184
1185查询当前进程所属的系统账号的信息。使用Promise异步回调。
1186
1187**系统接口:** 此接口为系统接口。
1188
1189**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.GET_LOCAL_ACCOUNTS
1190
1191**系统能力:** SystemCapability.Account.OsAccount
1192
1193**返回值:**
1194
1195| 类型                                           | 说明                                       |
1196| ---------------------------------------------- | ----------------------------------------- |
1197| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise对象,返回当前进程所属的系统账号信息。 |
1198
1199**错误码:**
1200
1201| 错误码ID | 错误信息             |
1202| -------- | ------------------- |
1203| 201 | Permission denied.|
1204| 202 | Not system application.|
1205| 12300001 | The system service works abnormally. |
1206
1207**示例:**
1208
1209  ```ts
1210  import { BusinessError } from '@kit.BasicServicesKit';
1211  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1212  try {
1213    accountManager.queryOsAccount().then((accountInfo: osAccount.OsAccountInfo) => {
1214      console.info('queryOsAccount, accountInfo: ' + JSON.stringify(accountInfo));
1215    }).catch((err: BusinessError) => {
1216      console.error(`queryOsAccount err: code is ${err.code}, message is ${err.message}`);
1217    });
1218  } catch (e) {
1219    const err = e as BusinessError;
1220    console.error(`queryOsAccount exception: code is ${err.code}, message is ${err.message}`);
1221  }
1222  ```
1223
1224### queryOsAccountById
1225
1226queryOsAccountById(localId: number, callback: AsyncCallback&lt;OsAccountInfo&gt;): void
1227
1228查询指定系统账号的信息。使用callback异步回调。
1229
1230**系统接口:** 此接口为系统接口。
1231
1232**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1233
1234**系统能力:** SystemCapability.Account.OsAccount
1235
1236**参数:**
1237
1238| 参数名   | 类型                                                 | 必填 | 说明                                                                       |
1239| -------- | ---------------------------------------------------- | ---- | ------------------------------------------------------------------------ |
1240| localId  | number                                               | 是   | 要查询的系统账号的ID。                                                      |
1241| callback | AsyncCallback&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | 是   | 回调函数。如果查询成功,err为null,data为查到的系统账号的信息;否则为错误对象。 |
1242
1243**错误码:**
1244
1245| 错误码ID | 错误信息             |
1246| -------- | ------------------- |
1247| 201 | Permission denied.|
1248| 202 | Not system application.|
1249| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1250| 12300001 | The system service works abnormally. |
1251| 12300002 | Invalid localId.    |
1252| 12300003 | Account not found. |
1253
1254**示例:** 查询ID为100的系统账号信息
1255
1256  ```ts
1257  import { BusinessError } from '@kit.BasicServicesKit';
1258  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1259  let localId: number = 100;
1260  try {
1261    accountManager.queryOsAccountById(localId, (err: BusinessError, accountInfo: osAccount.OsAccountInfo)=>{
1262      if (err) {
1263        console.error(`queryOsAccountById exception:code is ${err.code}, message is ${err.message}`);
1264      } else {
1265        console.info('queryOsAccountById accountInfo:' + JSON.stringify(accountInfo));
1266      }
1267    });
1268  } catch (e) {
1269    const err = e as BusinessError;
1270    console.error(`queryOsAccountById exception: code is ${err.code}, message is ${err.message}`);
1271  }
1272  ```
1273
1274### queryOsAccountById
1275
1276queryOsAccountById(localId: number): Promise&lt;OsAccountInfo&gt;
1277
1278查询指定系统账号的信息。使用Promise异步回调。
1279
1280**系统接口:** 此接口为系统接口。
1281
1282**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1283
1284**系统能力:** SystemCapability.Account.OsAccount
1285
1286**参数:**
1287
1288| 参数名  | 类型   | 必填 | 说明                 |
1289| ------- | ------ | ---- | -------------------- |
1290| localId | number | 是   | 要查询的系统账号的ID。 |
1291
1292**返回值:**
1293
1294| 类型                                           | 说明                                 |
1295| ---------------------------------------------- | ------------------------------------ |
1296| Promise&lt;[OsAccountInfo](js-apis-osAccount.md#osaccountinfo)&gt; | Promise对象,返回查到的系统账号的信息。 |
1297
1298**错误码:**
1299
1300| 错误码ID | 错误信息             |
1301| -------- | ------------------- |
1302| 201 | Permission denied.|
1303| 202 | Not system application.|
1304| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1305| 12300001 | The system service works abnormally. |
1306| 12300002 | Invalid localId. |
1307| 12300003 | Account not found. |
1308
1309**示例:** 查询ID为100的系统账号信息
1310
1311  ```ts
1312  import { BusinessError } from '@kit.BasicServicesKit';
1313  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1314  let localId: number = 100;
1315  try {
1316    accountManager.queryOsAccountById(localId).then((accountInfo: osAccount.OsAccountInfo) => {
1317      console.info('queryOsAccountById, accountInfo: ' + JSON.stringify(accountInfo));
1318    }).catch((err: BusinessError) => {
1319      console.error(`queryOsAccountById err: code is ${err.code}, message is ${err.message}`);
1320    });
1321  } catch (e) {
1322    const err = e as BusinessError;
1323    console.error(`queryOsAccountById exception: code is ${err.code}, message is ${err.message}`);
1324  }
1325  ```
1326
1327### getOsAccountProfilePhoto
1328
1329getOsAccountProfilePhoto(localId: number, callback: AsyncCallback&lt;string&gt;): void
1330
1331获取指定系统账号的头像信息。使用callback异步回调。
1332
1333**系统接口:** 此接口为系统接口。
1334
1335**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1336
1337**系统能力:** SystemCapability.Account.OsAccount
1338
1339**参数:**
1340
1341| 参数名   | 类型                        | 必填 | 说明                                                                         |
1342| -------- | --------------------------- | ---- | -------------------------------------------------------------------------- |
1343| localId  | number                      | 是   | 系统账号ID。                                                                |
1344| callback | AsyncCallback&lt;string&gt; | 是   | 回调函数。如果获取成功,err为null,data为指定系统账号的头像信息;否则为错误对象。 |
1345
1346**错误码:**
1347
1348| 错误码ID | 错误信息             |
1349| -------- | ------------------- |
1350| 201 | Permission denied.|
1351| 202 | Not system application.|
1352| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1353| 12300001 | The system service works abnormally. |
1354| 12300002 | Invalid localId.    |
1355| 12300003 | Account not found. |
1356
1357**示例:** 获取ID为100的系统账号的头像
1358
1359  ```ts
1360  import { BusinessError } from '@kit.BasicServicesKit';
1361  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1362  let localId: number = 100;
1363  try {
1364    accountManager.getOsAccountProfilePhoto(localId, (err: BusinessError, photo: string)=>{
1365      if (err) {
1366        console.error(`getOsAccountProfilePhoto exception:code is ${err.code}, message is ${err.message}`);
1367      } else {
1368        console.info('get photo:' + photo + ' by localId: ' + localId);
1369      }
1370    });
1371  } catch (e) {
1372    const err = e as BusinessError;
1373    console.error(`getOsAccountProfilePhoto exception: code is ${err.code}, message is ${err.message}`);
1374  }
1375  ```
1376
1377### getOsAccountProfilePhoto
1378
1379getOsAccountProfilePhoto(localId: number): Promise&lt;string&gt;
1380
1381获取指定系统账号的头像信息。使用Promise异步回调。
1382
1383**系统接口:** 此接口为系统接口。
1384
1385**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1386
1387**系统能力:** SystemCapability.Account.OsAccount
1388
1389**参数:**
1390
1391| 参数名  | 类型   | 必填 | 说明         |
1392| ------- | ------ | ---- | ------------ |
1393| localId | number | 是   | 系统账号ID。 |
1394
1395**返回值:**
1396
1397| 类型                  | 说明                                    |
1398| --------------------- | -------------------------------------- |
1399| Promise&lt;string&gt; | Promise对象,返回指定系统账号的头像信息。 |
1400
1401**错误码:**
1402
1403| 错误码ID | 错误信息             |
1404| -------- | ------------------- |
1405| 201 | Permission denied.|
1406| 202 | Not system application.|
1407| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1408| 12300001 | The system service works abnormally. |
1409| 12300002 | Invalid localId.    |
1410| 12300003 | Account not found. |
1411
1412**示例:** 获取ID为100的系统账号的头像
1413
1414  ```ts
1415  import { BusinessError } from '@kit.BasicServicesKit';
1416  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1417  let localId: number = 100;
1418  try {
1419    accountManager.getOsAccountProfilePhoto(localId).then((photo: string) => {
1420      console.info('getOsAccountProfilePhoto: ' + photo);
1421    }).catch((err: BusinessError) => {
1422      console.error(`getOsAccountProfilePhoto err: code is ${err.code}, message is ${err.message}`);
1423    });
1424  } catch (e) {
1425    const err = e as BusinessError;
1426    console.error(`getOsAccountProfilePhoto exception: code is ${err.code}, message is ${err.message}`);
1427  }
1428  ```
1429
1430### setOsAccountProfilePhoto
1431
1432setOsAccountProfilePhoto(localId: number, photo: string, callback: AsyncCallback&lt;void&gt;): void
1433
1434为指定系统账号设置头像信息。使用callback异步回调。
1435
1436**系统接口:** 此接口为系统接口。
1437
1438**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1439
1440**系统能力:** SystemCapability.Account.OsAccount
1441
1442**参数:**
1443
1444| 参数名   | 类型                      | 必填 | 说明         |
1445| -------- | ------------------------- | ---- | ------------ |
1446| localId  | number                    | 是   | 系统账号ID。 |
1447| photo    | string                    | 是   | 头像信息。   |
1448| callback | AsyncCallback&lt;void&gt; | 是   | 回调函数。如果设置成功,err为null,否则为错误对象。  |
1449
1450**错误码:**
1451
1452| 错误码ID | 错误信息             |
1453| -------- | ------------------- |
1454| 201 | Permission denied.|
1455| 202 | Not system application.|
1456| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1457| 12300001 | The system service works abnormally. |
1458| 12300002 | Invalid localId or photo.    |
1459| 12300003 | Account not found. |
1460| 12300008 | Restricted Account. |
1461
1462**示例:** 给ID为100的系统账号设置头像
1463
1464  ```ts
1465  import { BusinessError } from '@kit.BasicServicesKit';
1466  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1467  let localId: number = 100;
1468  let photo: string = ''+
1469  'Cxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAACwSURBVDhPvZLBDYMwDEV/ugsXRjAT0EHCOuFIBwkbdIRewi6unbiAyoGgSn1SFH85+Y'+
1470  'q/4ljARW62X+LHS8uIzjm4dXUYF+utzBikB52Jo5e5iEPKqpACk7R9NM2RvWm5tIkD2czLCUFNKLD6IjdMHFHDzws285MgGrT0xCtp3WOKHo'+
1471  '+7q0mP0DZW9pNmoEFUzrQjp5cCnaen2kSJXLFD8ghbXyZCMQf/8e8Ns1XVAG/XAgqKzVnJFAAAAABJRU5ErkJggg=='
1472  try {
1473    accountManager.setOsAccountProfilePhoto(localId, photo, (err: BusinessError)=>{
1474      if (err) {
1475        console.error(`setOsAccountProfilePhoto exception:code is ${err.code}, message is ${err.message}`);
1476      } else {
1477        console.info('setOsAccountProfilePhoto successful.');
1478      }
1479    });
1480  } catch (e) {
1481    const err = e as BusinessError;
1482    console.error(`setOsAccountProfilePhoto exception: code is ${err.code}, message is ${err.message}`);
1483  }
1484  ```
1485
1486### setOsAccountProfilePhoto
1487
1488setOsAccountProfilePhoto(localId: number, photo: string): Promise&lt;void&gt;
1489
1490为指定系统账号设置头像信息。使用Promise异步回调。
1491
1492**系统接口:** 此接口为系统接口。
1493
1494**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1495
1496**系统能力:** SystemCapability.Account.OsAccount
1497
1498**参数:**
1499
1500| 参数名  | 类型   | 必填 | 说明         |
1501| ------- | ------ | ---- | ------------ |
1502| localId | number | 是   | 系统账号ID。 |
1503| photo   | string | 是   | 头像信息。   |
1504
1505**返回值:**
1506
1507| 类型                | 说明                                 |
1508| ------------------- | ------------------------------------ |
1509| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
1510
1511**错误码:**
1512
1513| 错误码ID | 错误信息             |
1514| -------- | ------------------- |
1515| 201 | Permission denied.|
1516| 202 | Not system application.|
1517| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1518| 12300001 | The system service works abnormally. |
1519| 12300002 | Invalid localId or photo.    |
1520| 12300003 | Account not found. |
1521| 12300008 | Restricted Account. |
1522
1523**示例:** 给ID为100的系统账号设置头像
1524
1525  ```ts
1526  import { BusinessError } from '@kit.BasicServicesKit';
1527  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1528  let localId: number = 100;
1529  let photo: string = ''+
1530  'Cxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAACwSURBVDhPvZLBDYMwDEV/ugsXRjAT0EHCOuFIBwkbdIRewi6unbiAyoGgSn1SFH85+Y'+
1531  'q/4ljARW62X+LHS8uIzjm4dXUYF+utzBikB52Jo5e5iEPKqpACk7R9NM2RvWm5tIkD2czLCUFNKLD6IjdMHFHDzws285MgGrT0xCtp3WOKHo'+
1532  '+7q0mP0DZW9pNmoEFUzrQjp5cCnaen2kSJXLFD8ghbXyZCMQf/8e8Ns1XVAG/XAgqKzVnJFAAAAABJRU5ErkJggg=='
1533  try {
1534    accountManager.setOsAccountProfilePhoto(localId, photo).then(() => {
1535      console.info('setOsAccountProfilePhoto success');
1536    }).catch((err: BusinessError) => {
1537      console.error(`setOsAccountProfilePhoto err: code is ${err.code}, message is ${err.message}`);
1538    });
1539  } catch (e) {
1540    const err = e as BusinessError;
1541    console.error(`setOsAccountProfilePhoto exception: code is ${err.code}, message is ${err.message}`);
1542  }
1543  ```
1544
1545### on
1546
1547on(type: 'activate' | 'activating', name: string, callback: Callback&lt;number&gt;): void
1548
1549订阅系统账号的激活完成与激活中的事件。使用callback异步回调。
1550
1551**系统接口:** 此接口为系统接口。
1552
1553**需要权限:** ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1554
1555**系统能力:** SystemCapability.Account.OsAccount
1556
1557**参数:**
1558
1559| 参数名   | 类型                       | 必填 | 说明                                                         |
1560| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1561| type     | 'activate' \| 'activating' | 是   | 订阅类型,activate表示订阅的是账号已激活完成的事件,activating表示订阅的是账号正在激活的事件。 |
1562| name     | string                     | 是   | 订阅名称,可自定义,要求非空且长度不超过1024字节。           |
1563| callback | Callback&lt;number&gt;     | 是   | 订阅系统账号激活完成与激活中的事件回调,表示激活完成后或正在激活中的系统账号ID。    |
1564
1565**错误码:**
1566
1567| 错误码ID | 错误信息       |
1568| -------- | ------------- |
1569| 201 | Permission denied.|
1570| 202 | Not system application.|
1571| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1572| 12300001 | The system service works abnormally. |
1573| 12300002 | Invalid type or name. |
1574
1575**示例:**
1576
1577  ```ts
1578  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1579  function onCallback(receiveLocalId: number){
1580    console.info('receive localId:' + receiveLocalId);
1581  }
1582  try {
1583    accountManager.on('activating', 'osAccountOnOffNameA', onCallback);
1584  } catch (e) {
1585    const err = e as BusinessError;
1586    console.error(`receive localId exception: code is ${err.code}, message is ${err.message}`);
1587  }
1588  ```
1589
1590### off
1591
1592off(type: 'activate' | 'activating', name: string, callback?: Callback&lt;number&gt;): void
1593
1594取消订阅系统账号的激活完成与激活中的事件。使用callback异步回调。
1595
1596**系统接口:** 此接口为系统接口。
1597
1598**需要权限:** ohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS_EXTENSION
1599
1600**系统能力:** SystemCapability.Account.OsAccount
1601
1602**参数:**
1603
1604| 参数名   | 类型                       | 必填 | 说明                                                         |
1605| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1606| type     | 'activate' \| 'activating' | 是   | 取消订阅类型,activate表示取消订阅账号已激活完成的事件,activating取消订阅账号正在激活的事件。 |
1607| name     | string                     | 是   | 订阅名称,可自定义,要求非空且长度不超过1024字节,需要与订阅接口传入的值保持一致。 |
1608| callback | Callback&lt;number&gt;     | 否   | 取消订阅系统账号激活完成与激活中的事件回调,默认为空,表示取消该类型事件的所有回调。                      |
1609
1610**错误码:**
1611
1612| 错误码ID | 错误信息       |
1613| -------- | ------------- |
1614| 201 | Permission denied.|
1615| 202 | Not system application.|
1616| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1617| 12300001 | The system service works abnormally. |
1618| 12300002 | Invalid type or name. |
1619
1620**示例:**
1621
1622  ```ts
1623  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1624  function offCallback(){
1625    console.info('off enter')
1626  }
1627  try {
1628    accountManager.off('activating', 'osAccountOnOffNameA', offCallback);
1629  } catch (e) {
1630    const err = e as BusinessError;
1631    console.error(`off exception: code is ${err.code}, message is ${err.message}`);
1632  }
1633  ```
1634
1635### on<sup>12+</sup>
1636
1637on(type: 'switching', callback: Callback&lt;OsAccountSwitchEventData&gt;): void
1638
1639订阅系统账号的前后台正在切换事件。使用callback异步回调。
1640
1641**系统接口:** 此接口为系统接口。
1642
1643**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1644
1645**系统能力:** SystemCapability.Account.OsAccount
1646
1647**参数:**
1648
1649| 参数名   | 类型                       | 必填 | 说明                                                         |
1650| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1651| type     | 'switching'                 | 是   | 订阅类型,switching表示订阅的是系统账号的前后台正在切换事件。 |
1652| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | 是   | 订阅系统账号的前后台正在切换事件回调,表示切换前和切换后的系统账号ID。    |
1653
1654**错误码:**
1655
1656| 错误码ID | 错误信息       |
1657| -------- | ------------- |
1658| 201 | Permission denied.|
1659| 202 | Not system application.|
1660| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1661| 12300001 | The system service works abnormally. |
1662| 12300002 | Invalid type. |
1663
1664**示例:**
1665
1666  ```ts
1667  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1668  function onSwitchingCallback(eventData: osAccount.OsAccountSwitchEventData){
1669    console.info('receive eventData:' + JSON.stringify(eventData));
1670  }
1671  try {
1672    accountManager.on('switching', onSwitchingCallback);
1673  } catch (e) {
1674    const err = e as BusinessError;
1675    console.error(`receive eventData exception: code is ${err.code}, message is ${err.message}`);
1676  }
1677  ```
1678
1679### off<sup>12+</sup>
1680
1681off(type: 'switching', callback?: Callback&lt;OsAccountSwitchEventData&gt;): void
1682
1683取消订阅系统账号的前后台正在切换事件。使用callback异步回调。
1684
1685**系统接口:** 此接口为系统接口。
1686
1687**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1688
1689**系统能力:** SystemCapability.Account.OsAccount
1690
1691**参数:**
1692
1693| 参数名   | 类型                       | 必填 | 说明                                                         |
1694| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1695| type     | 'switching'                 | 是   | 取消订阅类型,switching表示取消订阅的是系统账号的前后台正在切换事件。 |
1696| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | 否   | 取消订阅系统账号的前后台正在切换事件回调,默认为空,表示取消该类型事件的所有回调。                      |
1697
1698**错误码:**
1699
1700| 错误码ID | 错误信息       |
1701| -------- | ------------- |
1702| 201 | Permission denied.|
1703| 202 | Not system application.|
1704| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1705| 12300001 | The system service works abnormally. |
1706| 12300002 | Invalid type. |
1707
1708**示例:**
1709
1710  ```ts
1711  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1712  try {
1713    accountManager.off('switching');
1714  } catch (e) {
1715    const err = e as BusinessError;
1716    console.error(`off exception: code is ${err.code}, message is ${err.message}`);
1717  }
1718  ```
1719
1720### on<sup>12+</sup>
1721
1722on(type: 'switched', callback: Callback&lt;OsAccountSwitchEventData&gt;): void
1723
1724订阅系统账号的前后台切换结束事件。使用callback异步回调。
1725
1726**系统接口:** 此接口为系统接口。
1727
1728**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1729
1730**系统能力:** SystemCapability.Account.OsAccount
1731
1732**参数:**
1733
1734| 参数名   | 类型                       | 必填 | 说明                                                         |
1735| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1736| type     | 'switched'                 | 是   | 订阅类型,switched表示订阅的是系统账号的前后台切换结束事件。 |
1737| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | 是   | 订阅系统账号的前后台切换结束事件回调,表示切换前和切换后的系统账号ID。    |
1738
1739**错误码:**
1740
1741| 错误码ID | 错误信息       |
1742| -------- | ------------- |
1743| 201 | Permission denied.|
1744| 202 | Not system application.|
1745| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1746| 12300001 | The system service works abnormally. |
1747| 12300002 | Invalid type. |
1748
1749**示例:**
1750
1751  ```ts
1752  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1753  function onSwitchedCallback(eventData: osAccount.OsAccountSwitchEventData){
1754    console.info('receive eventData:' + JSON.stringify(eventData));
1755  }
1756  try {
1757    accountManager.on('switched', onSwitchedCallback);
1758  } catch (e) {
1759    const err = e as BusinessError;
1760    console.error(`receive eventData exception: code is ${err.code}, message is ${err.message}`);
1761  }
1762  ```
1763
1764### off<sup>12+</sup>
1765
1766off(type: 'switched', callback?: Callback&lt;OsAccountSwitchEventData&gt;): void
1767
1768取消订阅系统账号的前后台切换结束事件。使用callback异步回调。
1769
1770**系统接口:** 此接口为系统接口。
1771
1772**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1773
1774**系统能力:** SystemCapability.Account.OsAccount
1775
1776**参数:**
1777
1778| 参数名   | 类型                       | 必填 | 说明                                                         |
1779| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
1780| type     | 'switched'                 | 是   | 取消订阅类型,switched表示取消订阅的是系统账号的前后台切换结束事件。 |
1781| callback | Callback&lt;[OsAccountSwitchEventData](#osaccountswitcheventdata12)&gt;     | 否   | 取消订阅系统账号的前后台切换结束事件回调,默认为空,表示取消该类型事件的所有回调。                      |
1782
1783**错误码:**
1784
1785| 错误码ID | 错误信息       |
1786| -------- | ------------- |
1787| 201 | Permission denied.|
1788| 202 | Not system application.|
1789| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1790| 12300001 | The system service works abnormally. |
1791| 12300002 | Invalid type. |
1792
1793**示例:**
1794
1795  ```ts
1796  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1797  try {
1798    accountManager.off('switched');
1799  } catch (e) {
1800    const err = e as BusinessError;
1801    console.error(`off exception: code is ${err.code}, message is ${err.message}`);
1802  }
1803  ```
1804
1805### getBundleIdForUid<sup>9+</sup>
1806
1807getBundleIdForUid(uid: number, callback: AsyncCallback&lt;number&gt;): void
1808
1809通过uid查询对应的bundleId,使用callback异步回调。
1810
1811**系统接口:** 此接口为系统接口。
1812
1813**系统能力:** SystemCapability.Account.OsAccount
1814
1815**参数:**
1816
1817| 参数名   | 类型                       | 必填 | 说明                                                                        |
1818| -------- | --------------------------- | ---- | ------------------------------------------------------------------------ |
1819| uid      | number                      | 是   | 进程uid。                                                                 |
1820| callback | AsyncCallback&lt;number&gt; | 是   | 回调函数。如果查询成功,err为null,data为与uid对应的bundleId;否则为错误对象。 |
1821
1822**错误码:**
1823
1824| 错误码ID | 错误信息       |
1825| -------- | ------------- |
1826| 202 | Not system application.|
1827| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1828| 12300001 | The system service works abnormally. |
1829| 12300002 | Invalid uid. |
1830
1831**示例:**
1832
1833  ```ts
1834  import { BusinessError } from '@kit.BasicServicesKit';
1835  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1836  let testUid: number = 1000000;
1837  try {
1838    accountManager.getBundleIdForUid(testUid, (err: BusinessError, bundleId: number) => {
1839      if (err) {
1840        console.error(`getBundleIdForUid errInfo:code is ${err.code}, message is ${err.message}`);
1841      } else {
1842        console.info('getBundleIdForUid bundleId:' + JSON.stringify(bundleId));
1843      }
1844    });
1845  } catch (e) {
1846    const err = e as BusinessError;
1847    console.error(`getBundleIdForUid exception: code is ${err.code}, message is ${err.message}`);
1848  }
1849  ```
1850
1851### getBundleIdForUid<sup>9+</sup>
1852
1853getBundleIdForUid(uid: number): Promise&lt;number&gt;
1854
1855通过uid查询对应的bundleId,使用Promise异步回调。
1856
1857**系统接口:** 此接口为系统接口。
1858
1859**系统能力:** SystemCapability.Account.OsAccount
1860
1861**参数:**
1862
1863| 参数名  | 类型   | 必填 | 说明         |
1864| ------- | ------ | ---- | ------------ |
1865| uid     | number | 是   |  进程uid。 |
1866
1867**返回值:**
1868
1869| 类型                  | 说明                                  |
1870| --------------------- | ------------------------------------ |
1871| Promise&lt;number&gt; | Promise对象,返回与uid对应的bundleId。 |
1872
1873**错误码:**
1874
1875| 错误码ID | 错误信息       |
1876| -------- | ------------- |
1877| 202 | Not system application.|
1878| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1879| 12300001 | The system service works abnormally. |
1880| 12300002 | Invalid uid. |
1881
1882**示例:**
1883
1884  ```ts
1885  import { BusinessError } from '@kit.BasicServicesKit';
1886  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1887  let testUid: number = 1000000;
1888  try {
1889    accountManager.getBundleIdForUid(testUid).then((result: number) => {
1890      console.info('getBundleIdForUid bundleId:' + JSON.stringify(result));
1891    }).catch((err: BusinessError) => {
1892      console.error(`getBundleIdForUid errInfo:code is ${err.code}, message is ${err.message}`);
1893    });
1894  } catch (e) {
1895    const err = e as BusinessError;
1896    console.error(`getBundleIdForUid exception: code is ${err.code}, message is ${err.message}`);
1897  }
1898  ```
1899
1900### getBundleIdForUidSync<sup>10+</sup>
1901
1902getBundleIdForUidSync(uid: number): number
1903
1904通过uid查询对应的bundleId。使用同步方式返回结果。
1905
1906**系统接口:** 此接口为系统接口。
1907
1908**系统能力:** SystemCapability.Account.OsAccount
1909
1910**参数:**
1911
1912| 参数名  | 类型   | 必填 | 说明         |
1913| ------- | ------ | ---- | ------------ |
1914| uid     | number | 是   |  进程uid。 |
1915
1916**返回值:**
1917
1918| 类型   | 说明                     |
1919| ------ | ------------------------ |
1920| number | 表示与进程uid对应的bundleId。 |
1921
1922**错误码:**
1923
1924| 错误码ID | 错误信息       |
1925| -------- | ------------- |
1926| 202 | Not system application.|
1927| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1928| 12300002 | Invalid uid. |
1929
1930**示例:**
1931
1932  ```ts
1933  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1934  let testUid: number = 1000000;
1935  try {
1936    let bundleId : number = accountManager.getBundleIdForUidSync(testUid);
1937    console.info('getBundleIdForUidSync bundleId:' + bundleId);
1938  } catch (e) {
1939    const err = e as BusinessError;
1940    console.error(`getBundleIdForUidSync exception: code is ${err.code}, message is ${err.message}`);
1941  }
1942  ```
1943
1944### isMainOsAccount<sup>9+</sup>
1945
1946isMainOsAccount(callback: AsyncCallback&lt;boolean&gt;): void
1947
1948查询当前进程是否处于主用户,使用callback异步回调。
1949
1950**系统接口:** 此接口为系统接口。
1951
1952**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1953
1954**系统能力:** SystemCapability.Account.OsAccount
1955
1956**参数:**
1957
1958| 参数名   | 类型                          | 必填 | 说明                                                               |
1959| -------- | ---------------------------- | ---- | ----------------------------------------------------------------- |
1960| callback | AsyncCallback&lt;boolean&gt; | 是   | 回调函数,返回true表示当前账号为主账号,返回false表示当前账号非主账号。 |
1961
1962**错误码:**
1963
1964| 错误码ID | 错误信息       |
1965| -------- | ------------- |
1966| 201 | Permission denied.|
1967| 202 | Not system application.|
1968| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
1969| 12300001 | The system service works abnormally. |
1970
1971**示例:**
1972
1973  ```ts
1974  import { BusinessError } from '@kit.BasicServicesKit';
1975  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
1976  try {
1977    accountManager.isMainOsAccount((err: BusinessError,result: boolean)=>{
1978      if (err) {
1979        console.error(`isMainOsAccount errInfo:code is ${err.code}, message is ${err.message}`);
1980      } else {
1981        console.info('isMainOsAccount result:' + JSON.stringify(result));
1982      }
1983    });
1984  } catch (e) {
1985    const err = e as BusinessError;
1986    console.error(`isMainOsAccount exception: code is ${err.code}, message is ${err.message}`);
1987  }
1988  ```
1989
1990### isMainOsAccount<sup>9+</sup>
1991
1992isMainOsAccount(): Promise&lt;boolean&gt;;
1993
1994查询当前进程是否处于主用户,使用Promise异步回调。
1995
1996**系统接口:** 此接口为系统接口。
1997
1998**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
1999
2000**系统能力:** SystemCapability.Account.OsAccount
2001
2002**返回值:**
2003
2004| 类型                   | 说明                                                                  |
2005| ---------------------- | --------------------------------------------------------------------- |
2006| Promise&lt;boolean&gt; | Promise对象,返回true表示当前账号为主账号,返回false表示当前账号非主账号。 |
2007
2008**错误码:**
2009
2010| 错误码ID | 错误信息       |
2011| -------- | ------------- |
2012| 201 | Permission denied.|
2013| 202 | Not system application.|
2014| 12300001 | The system service works abnormally. |
2015
2016**示例:**
2017
2018  ```ts
2019  import { BusinessError } from '@kit.BasicServicesKit';
2020  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
2021  try {
2022    accountManager.isMainOsAccount().then((result: boolean) => {
2023      console.info('isMainOsAccount result:' + JSON.stringify(result));
2024    }).catch((err: BusinessError) => {
2025      console.error(`isMainOsAccount errInfo:code is ${err.code}, message is ${err.message}`);
2026    });
2027  } catch (e) {
2028    const err = e as BusinessError;
2029    console.error(`isMainOsAccount exception: code is ${err.code}, message is ${err.message}`);
2030  }
2031  ```
2032
2033### getOsAccountConstraintSourceTypes<sup>9+</sup>
2034
2035getOsAccountConstraintSourceTypes(localId: number, constraint: string, callback: AsyncCallback&lt;Array&lt;ConstraintSourceTypeInfo&gt;&gt;): void
2036
2037查询指定系统账号的指定约束来源信息,使用callback异步回调。
2038
2039**系统接口:** 此接口为系统接口。
2040
2041**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
2042
2043**系统能力:** SystemCapability.Account.OsAccount
2044
2045**参数:**
2046
2047| 参数名   | 类型                       | 必填 | 说明                                                         |
2048| -------- | -------------------------- | ---- | ------------------------------------------------------------ |
2049| localId     | number | 是   |  要查询的系统账号ID。 |
2050| constraint     | string | 是   |  要查询的[约束](js-apis-osAccount.md#系统账号约束列表)名称。 |
2051| callback | AsyncCallback&lt;Array&lt;[ConstraintSourceTypeInfo](#constraintsourcetypeinfo9)&gt;&gt;     | 是   | 回调函数。如果成功,err为null,data为指定系统账号的指定[约束](js-apis-osAccount.md#系统账号约束列表)来源信息;否则为错误对象。                      |
2052
2053**错误码:**
2054
2055| 错误码ID | 错误信息       |
2056| -------- | ------------- |
2057| 201 | Permission denied.|
2058| 202 | Not system application.|
2059| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2060| 12300001 | The system service works abnormally. |
2061| 12300002 | Invalid name or constraint. |
2062| 12300003 | Account not found. |
2063
2064**示例:**
2065
2066  ```ts
2067  import { BusinessError } from '@kit.BasicServicesKit';
2068  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
2069  try {
2070    accountManager.getOsAccountConstraintSourceTypes(100, 'constraint.wifi',
2071      (err: BusinessError,sourceTypeInfos: osAccount.ConstraintSourceTypeInfo[])=>{
2072      if (err) {
2073        console.error(`getOsAccountConstraintSourceTypes errInfo:code is ${err.code}, message is ${err.message}`);
2074      } else {
2075        console.info('getOsAccountConstraintSourceTypes sourceTypeInfos:' + JSON.stringify(sourceTypeInfos));
2076      }
2077    });
2078  } catch (e) {
2079    const err = e as BusinessError;
2080    console.error(`getOsAccountConstraintSourceTypes exception: code is ${err.code}, message is ${err.message}`);
2081  }
2082  ```
2083
2084### getOsAccountConstraintSourceTypes<sup>9+</sup>
2085
2086getOsAccountConstraintSourceTypes(localId: number, constraint: string): Promise&lt;Array&lt;ConstraintSourceTypeInfo&gt;&gt;;
2087
2088查询指定系统账号的指定约束来源信息,使用Promise异步回调。
2089
2090**系统接口:** 此接口为系统接口。
2091
2092**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
2093
2094**系统能力:** SystemCapability.Account.OsAccount
2095
2096**参数:**
2097
2098| 参数名  | 类型   | 必填 | 说明         |
2099| ------- | ------ | ---- | ------------ |
2100| localId     | number | 是   |  要查询的系统账号ID。 |
2101| constraint     | string | 是   |  要查询的[约束](js-apis-osAccount.md#系统账号约束列表)名称。 |
2102
2103**返回值:**
2104
2105| 类型                  | 说明                                                         |
2106| --------------------- | ------------------------------------------------------------ |
2107| Promise&lt;Array&lt;[ConstraintSourceTypeInfo](#constraintsourcetypeinfo9)&gt;&gt; | Promise对象,返回指定系统账号的指定[约束](js-apis-osAccount.md#系统账号约束列表)来源信息。 |
2108
2109**错误码:**
2110
2111| 错误码ID | 错误信息       |
2112| -------- | ------------- |
2113| 201 | Permission denied.|
2114| 202 | Not system application.|
2115| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2116| 12300001 | The system service works abnormally. |
2117| 12300002 | Invalid name or constraint. |
2118| 12300003 | Account not found. |
2119
2120**示例:**
2121
2122  ```ts
2123  import { BusinessError } from '@kit.BasicServicesKit';
2124  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
2125  try {
2126    accountManager.getOsAccountConstraintSourceTypes(100, 'constraint.wifi').then(
2127      (result: osAccount.ConstraintSourceTypeInfo[]) => {
2128      console.info('getOsAccountConstraintSourceTypes sourceTypeInfos:' + JSON.stringify(result));
2129    }).catch((err: BusinessError) => {
2130      console.error(`getOsAccountConstraintSourceTypes errInfo:code is ${err.code}, message is ${err.message}`);
2131    });
2132  } catch (e) {
2133    const err = e as BusinessError;
2134    console.error(`getOsAccountConstraintSourceTypes exception: code is ${err.code}, message is ${err.message}`);
2135  }
2136  ```
2137
2138### getOsAccountType<sup>12+</sup>
2139
2140getOsAccountType(localId: number): Promise&lt;OsAccountType&gt;;
2141
2142查询指定系统账号的类型,使用Promise异步回调。
2143
2144**系统接口:** 此接口为系统接口。
2145
2146**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
2147
2148**系统能力:** SystemCapability.Account.OsAccount
2149
2150**参数:**
2151
2152| 参数名  | 类型   | 必填 | 说明         |
2153| ------- | ------ | ---- | ------------ |
2154| localId     | number | 是   |  要查询的系统账号ID。 |
2155
2156**返回值:**
2157
2158| 类型                  | 说明                                                         |
2159| --------------------- | ------------------------------------------------------------ |
2160| Promise&lt;[OsAccountType](js-apis-osAccount.md#osaccounttype)&gt; | Promise对象,返回指定系统账号的类型。 |
2161
2162**错误码:**
2163
2164| 错误码ID | 错误信息       |
2165| -------- | ------------- |
2166| 201 | Permission denied.|
2167| 202 | Not system application.|
2168| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2169| 12300001 | The system service works abnormally. |
2170| 12300003 | Account not found. |
2171
2172**示例:**
2173
2174  ```ts
2175  import { BusinessError } from '@kit.BasicServicesKit';
2176  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
2177  try {
2178    let localId: number = 100;
2179    accountManager.getOsAccountType(localId).then((type: osAccount.OsAccountType) => {
2180      console.info('getOsAccountType Type:' + type);
2181    }).catch((err: BusinessError) => {
2182      console.error(`getOsAccountType errInfo:code is ${err.code}, message is ${err.message}`);
2183    });
2184  } catch (e) {
2185    const err = e as BusinessError;
2186    console.error(`getOsAccountType exception: code is ${err.code}, message is ${err.message}`);
2187  }
2188  ```
2189
2190### bindDomainAccount<sup>20+</sup>
2191
2192bindDomainAccount(localId: number, domainAccountInfo: DomainAccountInfo): Promise&lt;void&gt;
2193
2194在指定系统账号上绑定指定域账号。使用Promise异步回调。
2195
2196**系统接口:** 此接口为系统接口。
2197
2198**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
2199
2200**系统能力:** SystemCapability.Account.OsAccount
2201
2202**参数:**
2203
2204| 参数名  | 类型   | 必填 | 说明         |
2205| ------- | ------ | ---- | ------------ |
2206| localId     | number | 是   |  要查询的系统账号ID。 |
2207| domainAccountInfo | [DomainAccountInfo](#domainaccountinfo8) | 是   | 域账号信息。          |
2208
2209**返回值:**
2210
2211| 类型                  | 说明                                                         |
2212| --------------------- | ------------------------------------------------------------ |
2213| Promise&lt;void&gt; | Promise对象,无返回结果。 |
2214
2215**错误码:**
2216
2217以下错误码的详细介绍请参见通用[错误码说明文档](../errorcode-universal.md)和[账号管理错误码](./errorcode-account.md)。
2218
2219| 错误码ID | 错误信息       |
2220| -------- | ------------- |
2221| 201 | Permission denied.|
2222| 202 | Not system application.|
2223| 801 | Capability not supported.|
2224| 12300001 | The system service works abnormally. |
2225| 12300002 | Invalid domain account information. |
2226| 12300003 | The OS account not found. |
2227| 12300008 | Restricted OS account. Possible causes: The OS account cannot be bound. |
2228| 12300010 | Service busy. Possible causes: The target OS account or domain account is being operated. |
2229| 12300021 | The OS account is already bound. |
2230| 12300022 | The domain account is already bound. |
2231
2232**示例:**
2233
2234  ```ts
2235  import { BusinessError } from '@kit.BasicServicesKit';
2236  let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
2237  try {
2238    let localId: number = 100;
2239    let domainInfo: osAccount.DomainAccountInfo =
2240      {domain: 'testDomain', accountName: 'testAccountName'};
2241    accountManager.bindDomainAccount(localId, domainInfo).then(() => {
2242      console.info('bindDomainAccount success.');
2243    }).catch((error: BusinessError) => {
2244      console.error(`bindDomainAccount failed, errCode=${error.code}, errMsg=${error.message}`);
2245    });
2246  } catch (e) {
2247    const err = e as BusinessError;
2248    console.error(`bindDomainAccount error, errCode=${error.code}, errMsg=${error.message}`);
2249  }
2250  ```
2251
2252## UserAuth<sup>8+</sup>
2253
2254用户认证类。
2255
2256**系统接口:** 此接口为系统接口。
2257
2258### constructor<sup>8+</sup>
2259
2260constructor()
2261
2262创建用户认证的实例。
2263
2264**系统接口:** 此接口为系统接口。
2265
2266**系统能力:** SystemCapability.Account.OsAccount
2267
2268**错误码:**
2269
2270| 错误码ID | 错误信息       |
2271| -------- | ------------- |
2272| 202 | Not system application.|
2273
2274**示例:**
2275  ```ts
2276  let userAuth = new osAccount.UserAuth();
2277  ```
2278
2279### getVersion<sup>8+</sup>
2280
2281getVersion(): number;
2282
2283返回版本信息。
2284
2285**系统接口:** 此接口为系统接口。
2286
2287**系统能力:** SystemCapability.Account.OsAccount
2288
2289**返回值:**
2290
2291| 类型   | 说明         |
2292| :----- | :----------- |
2293| number | 返回版本信息。|
2294
2295**错误码:**
2296
2297| 错误码ID | 错误信息       |
2298| -------- | ------------- |
2299| 202 | Not system application.|
2300
2301**示例:**
2302  ```ts
2303  let userAuth = new osAccount.UserAuth();
2304  let version: number = userAuth.getVersion();
2305  console.info('getVersion version = ' + version);
2306  ```
2307
2308### getAvailableStatus<sup>8+</sup>
2309
2310getAvailableStatus(authType: AuthType, authTrustLevel: AuthTrustLevel): number;
2311
2312获取指定认证类型和认证可信等级的认证能力的可用状态。
2313
2314**系统接口:** 此接口为系统接口。
2315
2316**系统能力:** SystemCapability.Account.OsAccount
2317
2318**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2319
2320**参数:**
2321
2322| 参数名           | 类型                               | 必填 | 说明                       |
2323| --------------- | -----------------------------------| ---- | ------------------------- |
2324| authType        | [AuthType](#authtype8)             | 是   | 认证类型。     |
2325| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8) | 是   | 认证的可信等级。 |
2326
2327**返回值:**
2328
2329| 类型   | 说明                           |
2330| ------ | ----------------------------- |
2331| number | 返回认证能力的可用状态。 |
2332
2333**错误码:**
2334
2335| 错误码ID | 错误信息                     |
2336| -------- | --------------------------- |
2337| 201 | Permission denied.|
2338| 202 | Not system application.|
2339| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2340| 12300001 | The system service works abnormally. |
2341| 12300002 | Invalid authType or authTrustLevel. |
2342
2343**示例:**
2344  ```ts
2345  let userAuth = new osAccount.UserAuth();
2346  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2347  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2348  try {
2349    let status: number = userAuth.getAvailableStatus(authType, authTrustLevel);
2350    console.info('getAvailableStatus status = ' + status);
2351  } catch (e) {
2352    const err = e as BusinessError;
2353    console.error(`getAvailableStatus exception = code is ${err.code}, message is ${err.message}`);
2354  }
2355  ```
2356
2357### getProperty<sup>8+</sup>
2358
2359getProperty(request: GetPropertyRequest, callback: AsyncCallback&lt;ExecutorProperty&gt;): void
2360
2361基于指定的请求信息获取属性。使用callback异步回调。
2362
2363**系统接口:** 此接口为系统接口。
2364
2365**系统能力:** SystemCapability.Account.OsAccount
2366
2367**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2368
2369**参数:**
2370
2371| 参数名    | 类型                                                                    | 必填 | 说明                                |
2372| -------- | ----------------------------------------------------------- | ---- | ------------------------------------------------------ |
2373| request  | [GetPropertyRequest](#getpropertyrequest8)                  | 是   | 请求信息,包括认证类型和属性类型列表。 |
2374| callback | AsyncCallback&lt;[ExecutorProperty](#executorproperty8)&gt; | 是   | 回调函数。如果获取成功,err为null,data为执行器属性信息;否则为错误对象。|
2375
2376**错误码:**
2377
2378| 错误码ID | 错误信息                     |
2379| -------- | --------------------------- |
2380| 201 | Permission denied.|
2381| 202 | Not system application.|
2382| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2383| 12300001 | The system service works abnormally. |
2384| 12300002 | Invalid request. |
2385| 12300003 | Account not found. |
2386
2387**示例:**
2388  ```ts
2389  import { BusinessError } from '@kit.BasicServicesKit';
2390  let userAuth = new osAccount.UserAuth();
2391  let keys: Array<osAccount.GetPropertyType>  = [
2392    osAccount.GetPropertyType.AUTH_SUB_TYPE,
2393    osAccount.GetPropertyType.REMAIN_TIMES,
2394    osAccount.GetPropertyType.FREEZING_TIME
2395  ];
2396  let request: osAccount.GetPropertyRequest = {
2397    authType: osAccount.AuthType.PIN,
2398    keys: keys
2399  };
2400  try {
2401    userAuth.getProperty(request, (err: BusinessError, result: osAccount.ExecutorProperty) => {
2402      if (err) {
2403        console.error(`getProperty exception = code is ${err.code}, message is ${err.message}`);
2404      } else {
2405        console.info('getProperty result = ' + JSON.stringify(result));
2406      }
2407    });
2408  } catch (e) {
2409    const err = e as BusinessError;
2410    console.error(`getProperty exception = code is ${err.code}, message is ${err.message}`);
2411  }
2412  ```
2413
2414### getProperty<sup>8+</sup>
2415
2416getProperty(request: GetPropertyRequest): Promise&lt;ExecutorProperty&gt;;
2417
2418基于指定的请求信息获取属性。使用Promise异步回调。
2419
2420**系统接口:** 此接口为系统接口。
2421
2422**系统能力:** SystemCapability.Account.OsAccount
2423
2424**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2425
2426**参数:**
2427
2428| 参数名    | 类型                                                   | 必填 | 说明                                |
2429| -------- | ------------------------------------------------------ | ---- | ---------------------------------- |
2430| request  | [GetPropertyRequest](#getpropertyrequest8) | 是   | 请求信息,包括认证类型和属性类型列表。 |
2431
2432**返回值:**
2433
2434| 类型                                                              | 说明                                                 |
2435| :---------------------------------------------------------------- | :-------------------------------------------------- |
2436| Promise&lt;[ExecutorProperty](#executorproperty8)&gt; | Promise对象,返回执行器属性信息。 |
2437
2438**错误码:**
2439
2440| 错误码ID | 错误信息                     |
2441| -------- | --------------------------- |
2442| 201 | Permission denied.|
2443| 202 | Not system application.|
2444| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2445| 12300001 | The system service works abnormally. |
2446| 12300002 | Invalid request. |
2447| 12300003 | Account not found. |
2448
2449**示例:**
2450  ```ts
2451  import { BusinessError } from '@kit.BasicServicesKit';
2452  let userAuth = new osAccount.UserAuth();
2453  let keys: Array<osAccount.GetPropertyType> = [
2454    osAccount.GetPropertyType.AUTH_SUB_TYPE,
2455    osAccount.GetPropertyType.REMAIN_TIMES,
2456    osAccount.GetPropertyType.FREEZING_TIME
2457  ];
2458  let request: osAccount.GetPropertyRequest = {
2459    authType: osAccount.AuthType.PIN,
2460    keys: keys
2461  };
2462  try {
2463    userAuth.getProperty(request).then((result: osAccount.ExecutorProperty) => {
2464      console.info('getProperty result = ' + JSON.stringify(result));
2465    }).catch((err: BusinessError) => {
2466      console.error(`getProperty error = code is ${err.code}, message is ${err.message}`);
2467    });
2468  } catch (e) {
2469    const err = e as BusinessError;
2470    console.error(`getProperty exception = code is ${err.code}, message is ${err.message}`);
2471  }
2472  ```
2473
2474### getPropertyByCredentialId<sup>14+</sup>
2475
2476getPropertyByCredentialId(credentialId: Uint8Array, keys: Array&lt;GetPropertyType&gt;): Promise&lt;ExecutorProperty&gt;;
2477
2478基于凭据id获取关联执行器的指定属性信息。使用Promise异步回调。
2479
2480**系统接口:** 此接口为系统接口。
2481
2482**系统能力:** SystemCapability.Account.OsAccount
2483
2484**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2485
2486**参数:**
2487
2488| 参数名    | 类型                                                   | 必填 | 说明                                |
2489| -------- | ------------------------------------------------------ | ---- | ---------------------------------- |
2490| credentialId  | Uint8Array | 是   | 指示凭据索引。 |
2491| keys     | Array&lt;[GetPropertyType](#getpropertytype8)&gt; | 是    | 指示要查询的属性类型数组。 |
2492
2493**返回值:**
2494
2495| 类型                                                              | 说明                                                 |
2496| :---------------------------------------------------------------- | :-------------------------------------------------- |
2497| Promise&lt;[ExecutorProperty](#executorproperty8)&gt; | Promise对象,返回执行器的属性信息。 |
2498
2499**错误码:**
2500
2501| 错误码ID | 错误信息                     |
2502| -------- | --------------------------- |
2503| 201 | Permission denied.|
2504| 202 | Not system application.|
2505| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2506| 12300001 | The system service works abnormally. |
2507| 12300002 | Invalid keys. |
2508| 12300102 | The credential does not exist. |
2509
2510**示例:**
2511  ```ts
2512  import { BusinessError } from '@kit.BasicServicesKit';
2513  let userIDM = new osAccount.UserIdentityManager();
2514  let credInfo: osAccount.EnrolledCredInfo[] = [];
2515  async function getProperty() {
2516    try {
2517      credInfo = await userIDM.getAuthInfo(osAccount.AuthType.PRIVATE_PIN);
2518    } catch (e) {
2519    const err = e as BusinessError;
2520      console.error(`getAuthInfo exception = code is ${err.code}, message is ${err.message}`);
2521      return;
2522    }
2523    if (credInfo.length == 0) {
2524      console.info('no credential infos');
2525      return;
2526    }
2527    let testCredentialId: Uint8Array = credInfo[0].credentialId;
2528    let keys: Array<osAccount.GetPropertyType> = [
2529      osAccount.GetPropertyType.AUTH_SUB_TYPE,
2530      osAccount.GetPropertyType.REMAIN_TIMES,
2531      osAccount.GetPropertyType.FREEZING_TIME
2532    ];
2533    try {
2534      let userAuth = new osAccount.UserAuth();
2535      userAuth.getPropertyByCredentialId(testCredentialId, keys).then((result: osAccount.ExecutorProperty) => {
2536        console.info('getPropertyByCredentialId result = ' + JSON.stringify(result));
2537      }).catch((err: BusinessError) => {
2538        console.error(`getPropertyByCredentialId error = code is ${err.code}, message is ${err.message}`);
2539      });
2540    } catch (e) {
2541    const err = e as BusinessError;
2542      console.error(`getPropertyByCredentialId exception = code is ${err.code}, message is ${err.message}`);
2543    }
2544  }
2545  ```
2546
2547### setProperty<sup>8+</sup>
2548
2549setProperty(request: SetPropertyRequest, callback: AsyncCallback&lt;void&gt;): void
2550
2551设置可用于初始化算法的属性。使用callback异步回调。
2552
2553**系统接口:** 此接口为系统接口。
2554
2555**系统能力:** SystemCapability.Account.OsAccount
2556
2557**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2558
2559**参数:**
2560
2561| 参数名    | 类型                                                  | 必填 | 说明                                                                    |
2562| -------- | ----------------------------------------------------- | ---- | ---------------------------------------------------------------------- |
2563| request  | [SetPropertyRequest](#setpropertyrequest8)| 是   | 请求信息,包括认证类型和要设置的密钥值。                                   |
2564| callback | AsyncCallback&lt;void&gt;                           | 是   | 回调函数。如果设置成功,err为null,否则为错误对象。 |
2565
2566**错误码:**
2567
2568| 错误码ID | 错误信息                     |
2569| -------- | --------------------------- |
2570| 201 | Permission denied.|
2571| 202 | Not system application.|
2572| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2573| 12300001 | The system service works abnormally. |
2574| 12300002 | Invalid request. |
2575
2576**示例:**
2577  ```ts
2578  import { BusinessError } from '@kit.BasicServicesKit';
2579  let userAuth = new osAccount.UserAuth();
2580  let request: osAccount.SetPropertyRequest = {
2581    authType: osAccount.AuthType.PIN,
2582    key: osAccount.SetPropertyType.INIT_ALGORITHM,
2583    setInfo: new Uint8Array([0])
2584  };
2585  try {
2586    userAuth.setProperty(request, (err: BusinessError) => {
2587      if (err) {
2588        console.error(`setProperty failed, error = code is ${err.code}, message is ${err.message}`);
2589      } else {
2590        console.info('setProperty successfully');
2591      }
2592    });
2593  } catch (e) {
2594    const err = e as BusinessError;
2595    console.error(`setProperty exception = code is ${err.code}, message is ${err.message}`);
2596  }
2597  ```
2598
2599### setProperty<sup>8+</sup>
2600
2601setProperty(request: SetPropertyRequest): Promise&lt;void&gt;;
2602
2603设置可用于初始化算法的属性。使用Promise异步回调。
2604
2605**系统接口:** 此接口为系统接口。
2606
2607**系统能力:** SystemCapability.Account.OsAccount
2608
2609**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2610
2611**参数:**
2612
2613| 参数名    | 类型                                       | 必填 | 说明                                      |
2614| -------- | ------------------------------------------ | ---- | ---------------------------------------- |
2615| request  | [SetPropertyRequest](#setpropertyrequest8) | 是   | 请求信息,包括身份验证类型和要设置的密钥值。 |
2616
2617**返回值:**
2618
2619| 类型                  | 说明                                                           |
2620| :-------------------- | :------------------------------------------------------------ |
2621| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
2622
2623**错误码:**
2624
2625| 错误码ID | 错误信息                     |
2626| -------- | --------------------------- |
2627| 201 | Permission denied.|
2628| 202 | Not system application.|
2629| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2630| 12300001 | The system service works abnormally. |
2631| 12300002 | Invalid request. |
2632
2633**示例:**
2634  ```ts
2635  import { BusinessError } from '@kit.BasicServicesKit';
2636  let userAuth = new osAccount.UserAuth();
2637  let request: osAccount.SetPropertyRequest = {
2638    authType: osAccount.AuthType.PIN,
2639    key: osAccount.SetPropertyType.INIT_ALGORITHM,
2640    setInfo: new Uint8Array([0])
2641  };
2642  try {
2643    userAuth.setProperty(request).then(() => {
2644      console.info('setProperty successfully');
2645    }).catch((err: BusinessError) => {
2646      console.error(`setProperty failed, error = code is ${err.code}, message is ${err.message}`);
2647    });
2648  } catch (e) {
2649    const err = e as BusinessError;
2650    console.error(`setProperty exception = code is ${err.code}, message is ${err.message}`);
2651  }
2652  ```
2653
2654### prepareRemoteAuth<sup>12+</sup>
2655
2656prepareRemoteAuth(remoteNetworkId: string): Promise&lt;void&gt;;
2657
2658准备远端认证。使用Promise异步回调。
2659
2660**系统接口:** 此接口为系统接口。
2661
2662**系统能力:** SystemCapability.Account.OsAccount
2663
2664**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2665
2666**参数:**
2667
2668| 参数名            | 类型   | 必填 | 说明             |
2669| --------         | ------ | ---- | --------------- |
2670| remoteNetworkId  | string | 是   | 远端网络Id。  |
2671
2672**返回值:**
2673
2674| 类型                  | 说明                                                           |
2675| :-------------------- | :------------------------------------------------------------ |
2676| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
2677
2678**错误码:**
2679
2680| 错误码ID | 错误信息                     |
2681| -------- | --------------------------- |
2682| 201 | Permission denied.|
2683| 202 | Not system application.|
2684| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2685| 12300001 | System service exception. |
2686| 12300002 | Invalid remoteNetworkId. |
2687| 12300090 | Cross-device capability not supported. |
2688| 12300091 | Cross-device communication failed. |
2689| 12300111 | Operation timeout. |
2690
2691**示例:**
2692  ```ts
2693  import { distributedDeviceManager } from '@kit.DistributedServiceKit';
2694  import { BusinessError } from '@kit.BasicServicesKit';
2695
2696  let userAuth = new osAccount.UserAuth();
2697  let distributedDeviceMgr = distributedDeviceManager.createDeviceManager("com.example.bundleName");
2698  distributedDeviceMgr.getAvailableDeviceList().then((data: Array<distributedDeviceManager.DeviceBasicInfo>) => {
2699      try {
2700        if (data.length > 0 && data[0].networkId != null) {
2701          userAuth.prepareRemoteAuth(data[0].networkId).then(() => {
2702            console.info('prepareRemoteAuth successfully');
2703          }).catch((err: BusinessError) => {
2704            console.error(`prepareRemoteAuth failed, error = code is ${err.code}, message is ${err.message}`);
2705          });
2706        }
2707      } catch (e) {
2708    const err = e as BusinessError;
2709        console.error(`prepareRemoteAuth exception = code is ${err.code}, message is ${err.message}`);
2710      }
2711    }
2712  )
2713  ```
2714
2715### auth<sup>8+</sup>
2716
2717auth(challenge: Uint8Array, authType: AuthType, authTrustLevel: AuthTrustLevel, callback: IUserAuthCallback): Uint8Array;
2718
2719认证当前用户。使用callback异步回调。
2720
2721**系统接口:** 此接口为系统接口。
2722
2723**系统能力:** SystemCapability.Account.OsAccount
2724
2725**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2726
2727**参数:**
2728
2729| 参数名           | 类型                                     | 必填 | 说明                                |
2730| --------------- | ---------------------------------------- | --- | ------------------------------------ |
2731| challenge       | Uint8Array                               | 是  | 指示挑战值,挑战值为一个随机数,用于提升安全性。|
2732| authType        | [AuthType](#authtype8)                   | 是  | 指示认证类型。                        |
2733| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8)       | 是  | 指示认证结果的信任级别。               |
2734| callback        | [IUserAuthCallback](#iuserauthcallback8) | 是  | 回调对象,返回认证结果。  |
2735
2736**返回值:**
2737
2738| 类型        | 说明               |
2739| ---------- | ------------------ |
2740| Uint8Array | 返回取消的上下文ID。 |
2741
2742**错误码:**
2743
2744| 错误码ID | 错误信息          |
2745| -------- | --------------------- |
2746| 201 | Permission denied.|
2747| 202 | Not system application.|
2748| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2749| 12300001 | The system service works abnormally. |
2750| 12300002 | Invalid challenge, authType or authTrustLevel. |
2751| 12300013 | Network exception. |
2752| 12300020 | Device hardware abnormal. |
2753| 12300090 | Cross-device capability not supported. |
2754| 12300091 | Cross-device communication failed. |
2755| 12300101 | The credential is incorrect. |
2756| 12300102 | The credential does not exist. |
2757| 12300105 | The trust level is not supported. |
2758| 12300106 | The authentication type is not supported. |
2759| 12300109 | The authentication, enrollment, or update operation is canceled. |
2760| 12300110 | The authentication is locked. |
2761| 12300111 | The authentication time out. |
2762| 12300112 | The authentication service is busy. |
2763| 12300113 | The authentication service does not exist. |
2764| 12300114 | The authentication service works abnormally. |
2765| 12300117 | PIN is expired. |
2766| 12300119 | Multi-factor authentication failed. |
2767| 12300211 | Server unreachable. |
2768
2769**示例:**
2770  ```ts
2771  let userAuth = new osAccount.UserAuth();
2772  let challenge: Uint8Array = new Uint8Array([0]);
2773  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2774  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2775  try {
2776    userAuth.auth(challenge, authType, authTrustLevel, {
2777      onResult: (result: number, extraInfo: osAccount.AuthResult) => {
2778          console.info('auth result = ' + result);
2779          console.info('auth extraInfo = ' + JSON.stringify(extraInfo));
2780      }
2781    });
2782  } catch (e) {
2783    const err = e as BusinessError;
2784    console.error(`auth exception = code is ${err.code}, message is ${err.message}`);
2785  }
2786  ```
2787
2788### auth<sup>12+</sup>
2789
2790auth(challenge: Uint8Array, authType: AuthType, authTrustLevel: AuthTrustLevel, options: AuthOptions, callback: IUserAuthCallback): Uint8Array
2791
2792基于指定的挑战值、认证类型(如口令、人脸、指纹等)、认证可信等级以及可选参数(如账号标识、认证意图等)进行身份认证。使用callback异步回调。
2793
2794**系统接口:** 此接口为系统接口。
2795
2796**系统能力:** SystemCapability.Account.OsAccount
2797
2798**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2799
2800**参数:**
2801
2802| 参数名           | 类型                                     | 必填 | 说明                                |
2803| --------------- | ---------------------------------------- | --- | ------------------------------------ |
2804| challenge       | Uint8Array                               | 是  | 指示挑战值,挑战值为一个随机数,用于防止重放攻击,提升安全性。|
2805| authType        | [AuthType](#authtype8)                   | 是  | 指示认证类型。                        |
2806| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8)       | 是  | 指示认证结果的信任级别。               |
2807| options         | [AuthOptions](#authoptions12) | 是 | 指示认证用户的可选参数集合。 |
2808| callback        | [IUserAuthCallback](#iuserauthcallback8) | 是  | 回调对象,返回认证结果。  |
2809
2810**返回值:**
2811
2812| 类型        | 说明               |
2813| ---------- | ------------------ |
2814| Uint8Array | 返回取消的上下文ID。 |
2815
2816**错误码:**
2817
2818| 错误码ID | 错误信息          |
2819| -------- | --------------------- |
2820| 201 | Permission denied.|
2821| 202 | Not system application.|
2822| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2823| 12300001 | The system service works abnormally. |
2824| 12300002 | Invalid challenge, authType, authTrustLevel or options. |
2825| 12300003 | Account not found. |
2826| 12300013 | Network exception. |
2827| 12300020 | Device hardware abnormal. |
2828| 12300090 | Cross-device capability not supported. |
2829| 12300091 | Cross-device communication failed. |
2830| 12300101 | The credential is incorrect. |
2831| 12300102 | The credential does not exist. |
2832| 12300105 | The trust level is not supported. |
2833| 12300106 | The authentication type is not supported. |
2834| 12300109 | The authentication, enrollment, or update operation is canceled. |
2835| 12300110 | The authentication is locked. |
2836| 12300111 | The authentication time out. |
2837| 12300112 | The authentication service is busy. |
2838| 12300113 | The authentication service does not exist. |
2839| 12300114 | The authentication service works abnormally. |
2840| 12300117 | PIN is expired. |
2841| 12300119 | Multi-factor authentication failed. |
2842| 12300211 | Server unreachable. |
2843
2844**示例:**
2845  ```ts
2846  let userAuth = new osAccount.UserAuth();
2847  let challenge: Uint8Array = new Uint8Array([0]);
2848  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2849  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2850  let options: osAccount.AuthOptions = {
2851    accountId: 100
2852  };
2853  try {
2854    userAuth.auth(challenge, authType, authTrustLevel, options, {
2855      onResult: (result: number, extraInfo: osAccount.AuthResult) => {
2856          console.info('auth result = ' + result);
2857          console.info('auth extraInfo = ' + JSON.stringify(extraInfo));
2858      }
2859    });
2860  } catch (e) {
2861    const err = e as BusinessError;
2862    console.error(`auth exception = code is ${err.code}, message is ${err.message}`);
2863  }
2864  ```
2865
2866### authUser<sup>8+</sup>
2867
2868authUser(userId: number, challenge: Uint8Array, authType: AuthType, authTrustLevel: AuthTrustLevel, callback: IUserAuthCallback): Uint8Array;
2869
2870认证指定用户。使用callback异步回调。
2871
2872**系统接口:** 此接口为系统接口。
2873
2874**系统能力:** SystemCapability.Account.OsAccount
2875
2876**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2877
2878**参数:**
2879
2880| 参数名           | 类型                                                 | 必填 | 说明                                |
2881| --------------- | ---------------------------------------------------- | --- | ------------------------------------ |
2882| userId          | number                                               | 是  | 指示用户身份。                        |
2883| challenge       | Uint8Array                                           | 是  | 指示挑战值,挑战值为一个随机数,用于提升安全性。                          |
2884| authType        | [AuthType](#authtype8)                   | 是  | 指示认证类型。                        |
2885| authTrustLevel  | [AuthTrustLevel](#authtrustlevel8)       | 是  | 指示认证结果的信任级别。               |
2886| callback        | [IUserAuthCallback](#iuserauthcallback8) | 是  | 回调对象,返回认证结果。  |
2887
2888**返回值:**
2889
2890| 类型        | 说明               |
2891| ---------- | ------------------ |
2892| Uint8Array | 返回取消的上下文ID。 |
2893
2894**错误码:**
2895
2896| 错误码ID | 错误信息          |
2897| -------- | --------------------- |
2898| 201 | Permission denied.|
2899| 202 | Not system application.|
2900| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2901| 12300001 | The system service works abnormally. |
2902| 12300002 | Invalid challenge, authType or authTrustLevel. |
2903| 12300003 | Account not found. |
2904| 12300013 | Network exception. |
2905| 12300020 | Device hardware abnormal. |
2906| 12300090 | Cross-device capability not supported. |
2907| 12300091 | Cross-device communication failed. |
2908| 12300101 | The credential is incorrect. |
2909| 12300102 | The credential does not exist. |
2910| 12300105 | The trust level is not supported. |
2911| 12300106 | The authentication type is not supported. |
2912| 12300109 | The authentication, enrollment, or update operation is canceled. |
2913| 12300110 | The authentication is locked. |
2914| 12300111 | The authentication time out. |
2915| 12300112 | The authentication service is busy. |
2916| 12300113 | The authentication service does not exist. |
2917| 12300114 | The authentication service works abnormally. |
2918| 12300117 | PIN is expired. |
2919| 12300119 | Multi-factor authentication failed. |
2920| 12300211 | Server unreachable. |
2921
2922**示例:**
2923  ```ts
2924  let userAuth = new osAccount.UserAuth();
2925  let userID: number = 100;
2926  let challenge: Uint8Array = new Uint8Array([0]);
2927  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
2928  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
2929  try {
2930    userAuth.authUser(userID, challenge, authType, authTrustLevel, {
2931      onResult: (result,extraInfo) => {
2932        console.info('authUser result = ' + result);
2933        console.info('authUser extraInfo = ' + JSON.stringify(extraInfo));
2934      }
2935    });
2936  } catch (e) {
2937    const err = e as BusinessError;
2938    console.error(`authUser exception = code is ${err.code}, message is ${err.message}`);
2939  }
2940  ```
2941
2942### cancelAuth<sup>8+</sup>
2943
2944cancelAuth(contextID: Uint8Array): void
2945
2946取消指定的认证操作。
2947
2948**系统接口:** 此接口为系统接口。
2949
2950**系统能力:** SystemCapability.Account.OsAccount
2951
2952**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
2953
2954**参数:**
2955
2956| 参数名    | 类型       | 必填  | 说明                                        |
2957| ----------| ---------- | ---- | ------------------------------------------ |
2958| contextID | Uint8Array | 是   | 指示身份验证上下文ID,此ID动态生成没有具体值。 |
2959
2960**错误码:**
2961
2962| 错误码ID | 错误信息            |
2963| -------- | ------------------ |
2964| 201 | Permission denied.|
2965| 202 | Not system application.|
2966| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
2967| 12300001 | The system service works abnormally. |
2968| 12300002 | Invalid contextId. |
2969
2970**示例:**
2971  ```ts
2972  let userAuth = new osAccount.UserAuth();
2973  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
2974  let challenge = new Uint8Array([0]);
2975  let contextId: Uint8Array = userAuth.auth(challenge, osAccount.AuthType.PIN, osAccount.AuthTrustLevel.ATL1, {
2976    onResult: (result: number, extraInfo: osAccount.AuthResult) => {
2977      console.info('auth result = ' + result);
2978      console.info('auth extraInfo = ' + JSON.stringify(extraInfo));
2979    }
2980  });
2981  try {
2982    userAuth.cancelAuth(contextId);
2983  } catch (e) {
2984    const err = e as BusinessError;
2985    console.error(`cancelAuth exception = code is ${err.code}, message is ${err.message}`);
2986  }
2987  ```
2988
2989## PINAuth<sup>8+</sup>
2990
2991PIN码认证基类。
2992
2993**系统接口:** 此接口为系统接口。
2994
2995### constructor<sup>8+</sup>
2996
2997constructor()
2998
2999创建PIN码认证的实例。
3000
3001**系统接口:** 此接口为系统接口。
3002
3003**系统能力:** SystemCapability.Account.OsAccount
3004
3005**错误码:**
3006
3007| 错误码ID | 错误信息       |
3008| -------- | ------------- |
3009| 202 | Not system application.|
3010
3011**示例:**
3012  ```ts
3013  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
3014  ```
3015
3016### registerInputer<sup>8+</sup>
3017
3018registerInputer(inputer: IInputer): void
3019
3020注册PIN码输入器。
3021
3022**系统接口:** 此接口为系统接口。
3023
3024**系统能力:** SystemCapability.Account.OsAccount
3025
3026**需要权限:** ohos.permission.ACCESS_PIN_AUTH
3027
3028**参数:**
3029
3030| 参数名    | 类型                     | 必填 | 说明                      |
3031| ----------| ----------------------- | --- | -------------------------- |
3032| inputer   | [IInputer](#iinputer8)  | 是  | PIN码输入器,用于获取PIN码。 |
3033
3034**错误码:**
3035
3036| 错误码ID | 错误信息                     |
3037| -------- | --------------------------- |
3038| 201 | Permission denied.|
3039| 202 | Not system application.|
3040| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3041| 12300001 | The system service works abnormally. |
3042| 12300002 | Invalid inputer. |
3043| 12300103 | The credential inputer already exists. |
3044
3045**示例:**
3046  ```ts
3047  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
3048  let password = new Uint8Array([0, 0, 0, 0, 0]);
3049  try {
3050    pinAuth.registerInputer({
3051        onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
3052          callback.onSetData(authSubType, password);
3053        }
3054    });
3055    console.info('registerInputer success.');
3056  } catch (e) {
3057    const err = e as BusinessError;
3058    console.error(`registerInputer exception = code is ${err.code}, message is ${err.message}`);
3059  }
3060  ```
3061
3062### unregisterInputer<sup>8+</sup>
3063
3064unregisterInputer(): void
3065
3066解注册PIN码输入器。
3067
3068**系统接口:** 此接口为系统接口。
3069
3070**系统能力:** SystemCapability.Account.OsAccount
3071
3072**需要权限:** ohos.permission.ACCESS_PIN_AUTH
3073
3074**错误码:**
3075
3076| 错误码ID | 错误信息                     |
3077| -------- | --------------------------- |
3078| 201 | Permission denied.|
3079| 202 | Not system application.|
3080
3081**示例:**
3082  ```ts
3083  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
3084  pinAuth.unregisterInputer();
3085  ```
3086
3087## InputerManager <sup>9+</sup>
3088
3089凭据输入管理器。
3090
3091### registerInputer<sup>9+</sup>
3092
3093static registerInputer(authType: AuthType, inputer: IInputer): void
3094
3095注册凭据输入器。
3096
3097**系统接口:** 此接口为系统接口。
3098
3099**系统能力:** SystemCapability.Account.OsAccount
3100
3101**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNALohos.permission.MANAGE_USER_IDM
3102
3103**参数:**
3104
3105| 参数名    | 类型                     | 必填 | 说明                      |
3106| ----------| ----------------------- | --- | -------------------------- |
3107| authType   | [AuthType](#authtype8)  | 是  | 认证类型。 |
3108| inputer   | [IInputer](#iinputer8)  | 是  | 凭据输入器,用于获取凭据。 |
3109
3110**错误码:**
3111
3112| 错误码ID | 错误信息                     |
3113| -------- | --------------------------- |
3114| 201 | Permission denied.|
3115| 202 | Not system application.|
3116| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3117| 12300001 | The system service works abnormally. |
3118| 12300002 | Invalid authType or inputer. |
3119| 12300103 | The credential inputer already exists. |
3120| 12300106 | The authentication type is not supported. |
3121
3122**示例:**
3123  ```ts
3124  let authType: osAccount.AuthType = osAccount.AuthType.DOMAIN;
3125  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0]);
3126  try {
3127    osAccount.InputerManager.registerInputer(authType, {
3128        onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
3129          callback.onSetData(authSubType, password);
3130        }
3131    });
3132    console.info('registerInputer success.');
3133  } catch (e) {
3134    const err = e as BusinessError;
3135    console.error(`registerInputer exception = code is ${err.code}, message is ${err.message}`);
3136  }
3137  ```
3138
3139### unregisterInputer<sup>9+</sup>
3140
3141static unregisterInputer(authType: AuthType): void
3142
3143解注册凭据输入器。
3144
3145**系统接口:** 此接口为系统接口。
3146
3147**系统能力:** SystemCapability.Account.OsAccount
3148
3149**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNALohos.permission.MANAGE_USER_IDM
3150
3151**参数:**
3152
3153| 参数名    | 类型                     | 必填 | 说明                      |
3154| ----------| ----------------------- | --- | -------------------------- |
3155| authType   | [AuthType](#authtype8)  | 是  | 认证类型。 |
3156
3157**错误码:**
3158
3159| 错误码ID | 错误信息                     |
3160| -------- | --------------------------- |
3161| 201 | Permission denied.|
3162| 202 | Not system application.|
3163| 401 |Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3164| 12300002  | Invalid authType. |
3165
3166**示例:**
3167  ```ts
3168  let authType: osAccount.AuthType = osAccount.AuthType.DOMAIN;
3169  try {
3170    osAccount.InputerManager.unregisterInputer(authType);
3171    console.info('unregisterInputer success.');
3172  } catch(err) {
3173    console.error(`unregisterInputer code is ${err.code}, message is ${err.message}`);
3174  }
3175  ```
3176
3177## DomainPlugin<sup>9+</sup>
3178
3179域插件,提供域账号认证功能。
3180
3181**系统接口:** 此接口为系统接口。
3182
3183### auth<sup>9+</sup>
3184
3185auth(domainAccountInfo: DomainAccountInfo, credential: Uint8Array, callback: IUserAuthCallback): void
3186
3187认证指定的域账号。
3188
3189**系统接口:** 此接口为系统接口。
3190
3191**系统能力:** SystemCapability.Account.OsAccount
3192
3193**参数:**
3194
3195| 参数名      | 类型                                    | 必填 | 说明             |
3196| ---------- | --------------------------------------- | ---- | --------------- |
3197| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3198| credential   | Uint8Array  | 是   | 指示域账号的凭据。|
3199| callback   | [IUserAuthCallback](#iuserauthcallback8)  | 是   | 指示认证结果回调。|
3200
3201**示例:**
3202  ```ts
3203  import { AsyncCallback } from '@kit.BasicServicesKit';
3204  let plugin: osAccount.DomainPlugin = {
3205    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3206          callback: osAccount.IUserAuthCallback) => {
3207      // mock authentication
3208      // notify authentication result
3209      let result: osAccount.AuthResult = {
3210        token: new Uint8Array([0]),
3211        remainTimes: 5,
3212        freezingTime: 0
3213      };
3214      callback.onResult(0, result);
3215    },
3216    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3217                    callback: osAccount.IUserAuthCallback) => {},
3218    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3219                    callback: osAccount.IUserAuthCallback) => {},
3220    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3221                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3222    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3223                      callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3224    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3225                  callback: AsyncCallback<void>) => {},
3226    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3227    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3228                          callback: AsyncCallback<boolean>) => {},
3229    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3230  }
3231  osAccount.DomainAccountManager.registerPlugin(plugin);
3232  let userAuth = new osAccount.UserAuth();
3233  let challenge: Uint8Array = new Uint8Array([0]);
3234  let authType: osAccount.AuthType = osAccount.AuthType.DOMAIN;
3235  let authTrustLevel: osAccount.AuthTrustLevel = osAccount.AuthTrustLevel.ATL1;
3236  try {
3237    userAuth.auth(challenge, authType, authTrustLevel, {
3238      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3239          console.info('auth resultCode = ' + resultCode);
3240          console.info('auth authResult = ' + JSON.stringify(authResult));
3241      }
3242    });
3243  } catch (err) {
3244    const err = err as BusinessError;
3245    console.error(`auth exception = code is ${err.code}, message is ${err.message}`);
3246  }
3247  ```
3248
3249### authWithPopup<sup>10+</sup>
3250
3251authWithPopup(domainAccountInfo: DomainAccountInfo, callback: IUserAuthCallback): void
3252
3253弹窗认证指定的域账号。
3254
3255**系统接口:** 此接口为系统接口。
3256
3257**系统能力:** SystemCapability.Account.OsAccount
3258
3259**参数:**
3260
3261| 参数名      | 类型                                    | 必填 | 说明             |
3262| ---------- | --------------------------------------- | ---- | --------------- |
3263| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3264| callback   | [IUserAuthCallback](#iuserauthcallback8)  | 是   | 指示认证结果回调。|
3265
3266**示例:**
3267  ```ts
3268  import { AsyncCallback } from '@kit.BasicServicesKit';
3269  let plugin: osAccount.DomainPlugin = {
3270    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3271          callback: osAccount.IUserAuthCallback) => {},
3272    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3273                    callback: osAccount.IUserAuthCallback) => {
3274      // mock authentication
3275      // notify authentication result
3276      let result: osAccount.AuthResult = {
3277        token: new Uint8Array([0]),
3278        remainTimes: 5,
3279        freezingTime: 0
3280      };
3281      callback.onResult(0, result);
3282    },
3283    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3284                    callback: osAccount.IUserAuthCallback) => {},
3285    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3286                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3287    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3288                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3289    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3290                  callback: AsyncCallback<void>) => {},
3291    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3292    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3293                          callback: AsyncCallback<boolean>) => {},
3294    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3295  }
3296  osAccount.DomainAccountManager.registerPlugin(plugin)
3297  ```
3298
3299### authWithToken<sup>10+</sup>
3300
3301authWithToken(domainAccountInfo: DomainAccountInfo, token: Uint8Array, callback: IUserAuthCallback): void
3302
3303使用授权令牌认证指定的域账号。
3304
3305**系统接口:** 此接口为系统接口。
3306
3307**系统能力:** SystemCapability.Account.OsAccount
3308
3309**参数:**
3310
3311| 参数名      | 类型                                    | 必填 | 说明             |
3312| ---------- | --------------------------------------- | ---- | --------------- |
3313| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3314| token   | Uint8Array  | 是   | 指示PIN码或生物识别认证成功时生成的授权令牌。|
3315| callback   | [IUserAuthCallback](#iuserauthcallback8)  | 是   | 指示认证结果回调。|
3316
3317**示例:**
3318  ```ts
3319  import { AsyncCallback } from '@kit.BasicServicesKit';
3320  let plugin: osAccount.DomainPlugin = {
3321    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3322          callback: osAccount.IUserAuthCallback) => {},
3323    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3324                    callback: osAccount.IUserAuthCallback) => {},
3325    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3326                    callback: osAccount.IUserAuthCallback) => {
3327      // mock authentication
3328      // notify authentication result
3329      let result: osAccount.AuthResult = {
3330        token: new Uint8Array([0]),
3331        remainTimes: 5,
3332        freezingTime: 0
3333      };
3334      callback.onResult(0, result);
3335    },
3336    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3337                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3338    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3339                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3340    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3341                  callback: AsyncCallback<void>) => {},
3342    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3343    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3344                          callback: AsyncCallback<boolean>) => {},
3345    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3346  }
3347  osAccount.DomainAccountManager.registerPlugin(plugin)
3348  ```
3349
3350### getAccountInfo<sup>10+</sup>
3351
3352getAccountInfo(options: GetDomainAccountInfoPluginOptions, callback: AsyncCallback&lt;DomainAccountInfo&gt;): void
3353
3354查询指定域账号的信息。
3355
3356**系统接口:** 此接口为系统接口。
3357
3358**系统能力:** SystemCapability.Account.OsAccount
3359
3360**参数:**
3361
3362| 参数名      | 类型                                    | 必填 | 说明             |
3363| ---------- | --------------------------------------- | ---- | --------------- |
3364| options   | [GetDomainAccountInfoPluginOptions](#getdomainaccountinfopluginoptions10)  | 是   | 指示域账号信息。|
3365| callback   | AsyncCallback&lt;[DomainAccountInfo](#domainaccountinfo8)&gt; | 是   | 指示查询结果回调。|
3366
3367**示例:**
3368  ```ts
3369  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3370  let plugin: osAccount.DomainPlugin = {
3371    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3372          callback: osAccount.IUserAuthCallback) => {},
3373    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3374                    callback: osAccount.IUserAuthCallback) => {},
3375    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3376                    callback: osAccount.IUserAuthCallback) => {},
3377    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3378                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {
3379      // mock getting account information
3380      // notify result
3381      let code: BusinessError = {
3382        code: 0,
3383        name: "",
3384        message: ""
3385      };
3386      let accountInfo: osAccount.DomainAccountInfo = {
3387        domain: options.domain ? options.domain : "",
3388        accountName: options.accountName,
3389        accountId: 'xxxx'
3390      };
3391      callback(code, accountInfo);
3392    },
3393    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3394                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3395    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3396                  callback: AsyncCallback<void>) => {},
3397    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3398    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3399                          callback: AsyncCallback<boolean>) => {},
3400    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3401  }
3402  osAccount.DomainAccountManager.registerPlugin(plugin)
3403  ```
3404
3405### getAuthStatusInfo<sup>10+</sup>
3406
3407getAuthStatusInfo(domainAccountInfo: DomainAccountInfo, callback: AsyncCallback&lt;AuthStatusInfo&gt;): void
3408
3409查询指定域账号的认证状态信息。
3410
3411**系统接口:** 此接口为系统接口。
3412
3413**系统能力:** SystemCapability.Account.OsAccount
3414
3415**参数:**
3416
3417| 参数名      | 类型                                    | 必填 | 说明             |
3418| ---------- | --------------------------------------- | ---- | --------------- |
3419| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3420| callback   | AsyncCallback&lt;[AuthStatusInfo](#authstatusinfo10)&gt; | 是   | 指示查询结果回调。|
3421
3422**示例:**
3423  ```ts
3424  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3425  let plugin: osAccount.DomainPlugin = {
3426    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3427          callback: osAccount.IUserAuthCallback) => {},
3428    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3429                    callback: osAccount.IUserAuthCallback) => {},
3430    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3431                    callback: osAccount.IUserAuthCallback) => {},
3432    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3433                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3434    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3435                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {
3436      let code: BusinessError = {
3437        code: 0,
3438        name: "",
3439        message: ""
3440      };
3441      let statusInfo: osAccount.AuthStatusInfo = {
3442        remainTimes: 5,
3443        freezingTime: 0
3444      };
3445      callback(code, statusInfo);
3446    },
3447    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3448                  callback: AsyncCallback<void>) => {},
3449    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3450    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3451                          callback: AsyncCallback<boolean>) => {},
3452    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3453  }
3454  osAccount.DomainAccountManager.registerPlugin(plugin)
3455  ```
3456
3457### bindAccount<sup>10+</sup>
3458
3459bindAccount(domainAccountInfo: DomainAccountInfo, localId: number, callback: AsyncCallback&lt;void&gt;): void
3460
3461绑定指定的域账号。
3462
3463**系统接口:** 此接口为系统接口。
3464
3465**系统能力:** SystemCapability.Account.OsAccount
3466
3467**参数:**
3468
3469| 参数名      | 类型                                    | 必填 | 说明             |
3470| ---------- | --------------------------------------- | ---- | --------------- |
3471| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3472| localId             | number  | 是   | 系统账号ID。 |
3473| callback   | AsyncCallback&lt;void&gt; | 是   | 指示绑定结果回调。|
3474
3475**示例:**
3476  ```ts
3477  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3478  let plugin: osAccount.DomainPlugin = {
3479    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3480          callback: osAccount.IUserAuthCallback) => {},
3481    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3482                    callback: osAccount.IUserAuthCallback) => {},
3483    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3484                    callback: osAccount.IUserAuthCallback) => {},
3485    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3486                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3487    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3488                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3489    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3490                  callback: AsyncCallback<void>) => {
3491      // mock unbinding operation
3492      // notify binding result
3493      let code: BusinessError = {
3494        code: 0,
3495        name: "",
3496        message: ""
3497      };
3498      callback(code);
3499    },
3500    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3501    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3502                          callback: AsyncCallback<boolean>) => {},
3503    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3504  }
3505  osAccount.DomainAccountManager.registerPlugin(plugin)
3506  ```
3507
3508### unbindAccount<sup>10+</sup>
3509
3510unbindAccount(domainAccountInfo: DomainAccountInfo, callback: AsyncCallback&lt;void&gt;): void
3511
3512解绑指定的域账号。
3513
3514**系统接口:** 此接口为系统接口。
3515
3516**系统能力:** SystemCapability.Account.OsAccount
3517
3518**参数:**
3519
3520| 参数名      | 类型                                    | 必填 | 说明             |
3521| ---------- | --------------------------------------- | ---- | --------------- |
3522| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3523| callback   | AsyncCallback&lt;void&gt; | 是   | 指示绑定结果回调。|
3524
3525**示例:**
3526  ```ts
3527  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3528  let plugin: osAccount.DomainPlugin = {
3529    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3530          callback: osAccount.IUserAuthCallback) => {},
3531    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3532                    callback: osAccount.IUserAuthCallback) => {},
3533    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3534                    callback: osAccount.IUserAuthCallback) => {},
3535    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3536                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3537    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3538                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3539    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3540                  callback: AsyncCallback<void>) => {},
3541    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {
3542      // mock unbinding operation
3543      // notify unbinding result
3544      let code: BusinessError = {
3545        code: 0,
3546        name: "",
3547        message: ""
3548      };
3549      callback(code);
3550    },
3551    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3552                          callback: AsyncCallback<boolean>) => {},
3553    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3554  }
3555  osAccount.DomainAccountManager.registerPlugin(plugin)
3556  ```
3557
3558### isAccountTokenValid<sup>10+</sup>
3559
3560isAccountTokenValid(domainAccountInfo: DomainAccountInfo, token: Uint8Array, callback: AsyncCallback&lt;boolean&gt;): void
3561
3562检查指定的域账号令牌是否有效。
3563
3564**系统接口:** 此接口为系统接口。
3565
3566**系统能力:** SystemCapability.Account.OsAccount
3567
3568**参数:**
3569
3570| 参数名      | 类型                                    | 必填 | 说明             |
3571| ---------- | --------------------------------------- | ---- | --------------- |
3572| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3573| token | Uint8Array | 是 | 指示域账号令牌。 |
3574| callback   | AsyncCallback&lt;boolean&gt; | 是   | 指示检查结果回调。true表示指定的域账号令牌是有效的;false表示指定的域账号令牌是无效的。|
3575
3576**示例:**
3577  ```ts
3578  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3579  let plugin: osAccount.DomainPlugin = {
3580    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3581          callback: osAccount.IUserAuthCallback) => {},
3582    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3583                    callback: osAccount.IUserAuthCallback) => {},
3584    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3585                    callback: osAccount.IUserAuthCallback) => {},
3586    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3587                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3588    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3589                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3590    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3591                  callback: AsyncCallback<void>) => {},
3592    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3593    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3594                          callback: AsyncCallback<boolean>) => {
3595      // mock checking operation
3596      // notify checking result
3597      let code: BusinessError = {
3598        code: 0,
3599        name: "",
3600        message: ""
3601      };
3602      callback(code, true);
3603    },
3604    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3605  }
3606  osAccount.DomainAccountManager.registerPlugin(plugin)
3607  ```
3608
3609### getAccessToken<sup>10+</sup>
3610
3611getAccessToken(options: GetDomainAccessTokenOptions, callback: AsyncCallback&lt;Uint8Array&gt;): void
3612
3613根据指定的选项获取域访问令牌。
3614
3615**系统接口:** 此接口为系统接口。
3616
3617**系统能力:** SystemCapability.Account.OsAccount
3618
3619**参数:**
3620
3621| 参数名      | 类型                                    | 必填 | 说明             |
3622| ---------- | --------------------------------------- | ---- | --------------- |
3623| options | [GetDomainAccessTokenOptions](#getdomainaccesstokenoptions10)  | 是   | 指示获取域访问令牌的选项。|
3624| callback   | AsyncCallback&lt;Uint8Array&gt; | 是   | 指示结果回调。|
3625
3626**示例:**
3627  ```ts
3628  import { AsyncCallback, BusinessError } from '@kit.BasicServicesKit';
3629  let plugin: osAccount.DomainPlugin = {
3630    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3631          callback: osAccount.IUserAuthCallback) => {},
3632    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3633                    callback: osAccount.IUserAuthCallback) => {},
3634    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3635                    callback: osAccount.IUserAuthCallback) => {},
3636    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3637                    callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3638    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3639                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3640    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3641                  callback: AsyncCallback<void>) => {},
3642    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3643    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3644                          callback: AsyncCallback<boolean>) => {},
3645    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {
3646      // mock getting operation
3647      // notify result
3648      let code: BusinessError = {
3649        code: 0,
3650        name: "",
3651        message: ""
3652      };
3653      let token: Uint8Array = new Uint8Array([0]);
3654      callback(code, token);
3655    }
3656  }
3657  osAccount.DomainAccountManager.registerPlugin(plugin)
3658  ```
3659
3660## DomainAccountManager <sup>9+</sup>
3661域账号管理器类。
3662
3663### registerPlugin<sup>9+</sup>
3664
3665static registerPlugin(plugin: DomainPlugin): void
3666
3667注册域插件。
3668
3669**系统接口:** 此接口为系统接口。
3670
3671**系统能力:** SystemCapability.Account.OsAccount
3672
3673**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
3674
3675**参数:**
3676
3677| 参数名    | 类型                     | 必填 | 说明                      |
3678| ----------| ----------------------- | --- | -------------------------- |
3679| plugin   | [DomainPlugin](#domainplugin9)  | 是  | 指示域插件。 |
3680
3681**错误码:**
3682
3683| 错误码ID | 错误信息                     |
3684| -------- | --------------------------- |
3685| 201 | Permission denied.|
3686| 202 | Not system application.|
3687| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3688| 801 | Capability not supported.|
3689| 12300201 | The domain plugin has been registered. |
3690
3691**示例:**
3692  ```ts
3693  import { AsyncCallback } from '@kit.BasicServicesKit';
3694  let plugin: osAccount.DomainPlugin = {
3695    auth: (domainAccountInfo: osAccount.DomainAccountInfo, credential: Uint8Array,
3696         callback: osAccount.IUserAuthCallback) => {},
3697    authWithPopup: (domainAccountInfo: osAccount.DomainAccountInfo,
3698                  callback: osAccount.IUserAuthCallback) => {},
3699    authWithToken: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3700                  callback: osAccount.IUserAuthCallback) => {},
3701    getAccountInfo: (options: osAccount.GetDomainAccountInfoPluginOptions,
3702                   callback: AsyncCallback<osAccount.DomainAccountInfo>) => {},
3703    getAuthStatusInfo: (domainAccountInfo: osAccount.DomainAccountInfo,
3704                        callback: AsyncCallback<osAccount.AuthStatusInfo>) => {},
3705    bindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, localId: number,
3706                  callback: AsyncCallback<void>) => {},
3707    unbindAccount: (domainAccountInfo: osAccount.DomainAccountInfo, callback: AsyncCallback<void>) => {},
3708    isAccountTokenValid: (domainAccountInfo: osAccount.DomainAccountInfo, token: Uint8Array,
3709                        callback: AsyncCallback<boolean>) => {},
3710    getAccessToken: (options: osAccount.GetDomainAccessTokenOptions, callback: AsyncCallback<Uint8Array>) => {}
3711  }
3712  try {
3713    osAccount.DomainAccountManager.registerPlugin(plugin);
3714    console.info('registerPlugin success.');
3715  } catch(err) {
3716    console.error(`registerPlugin code is ${err.code}, message is ${err.message}`);
3717  }
3718  ```
3719
3720### unregisterPlugin<sup>9+</sup>
3721
3722static unregisterPlugin(): void
3723
3724注销域插件。
3725
3726**系统接口:** 此接口为系统接口。
3727
3728**系统能力:** SystemCapability.Account.OsAccount
3729
3730**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
3731
3732**错误码:**
3733
3734| 错误码ID | 错误信息                     |
3735| -------- | --------------------------- |
3736| 201 | Permission denied.|
3737| 202 | Not system application.|
3738| 801 | Capability not supported.|
3739
3740**示例:**
3741  ```ts
3742  try {
3743    osAccount.DomainAccountManager.unregisterPlugin();
3744    console.info('unregisterPlugin success.');
3745  } catch(err) {
3746    console.error(`unregisterPlugin code is ${err.code}, message is ${err.message}`);
3747  }
3748  ```
3749
3750### auth<sup>10+</sup>
3751
3752auth(domainAccountInfo: DomainAccountInfo, credential: Uint8Array, callback: IUserAuthCallback): void
3753
3754认证指定的域账号。
3755
3756**系统接口:** 此接口为系统接口。
3757
3758**系统能力:** SystemCapability.Account.OsAccount
3759
3760**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
3761
3762**参数:**
3763
3764| 参数名      | 类型                                    | 必填 | 说明             |
3765| ---------- | --------------------------------------- | ---- | --------------- |
3766| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3767| credential   | Uint8Array  | 是   | 指示域账号的凭据。|
3768| callback   | [IUserAuthCallback](#iuserauthcallback8)  | 是   | 指示认证结果回调。|
3769
3770**错误码:**
3771
3772| 错误码ID | 错误信息                     |
3773| -------- | --------------------------- |
3774| 201 | Permission denied.|
3775| 202 | Not system application.|
3776| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3777| 801 | Capability not supported.|
3778| 12300001 | The system service works abnormally. |
3779| 12300002 | Invalid domainAccountInfo or credential. |
3780| 12300003 | Domain account does not exist. |
3781| 12300013 | Network exception. |
3782| 12300101 | Authentication failed. |
3783| 12300109 | The authentication, enrollment, or update operation is canceled. |
3784| 12300110 | The authentication is locked. |
3785| 12300111 | The authentication time out. |
3786| 12300112 | The authentication service is busy. |
3787| 12300113 | The account authentication service does not exist. |
3788| 12300114 | The account authentication service works abnormally. |
3789| 12300211 | Server unreachable. |
3790
3791**示例:**
3792  ```ts
3793  let domainAccountInfo: osAccount.DomainAccountInfo = {
3794    domain: 'CHINA',
3795    accountName: 'zhangsan'
3796  }
3797  let credential = new Uint8Array([0])
3798  try {
3799    osAccount.DomainAccountManager.auth(domainAccountInfo, credential, {
3800      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3801        console.info('auth resultCode = ' + resultCode);
3802        console.info('auth authResult = ' + JSON.stringify(authResult));
3803      }
3804    });
3805  } catch (err) {
3806    const err = err as BusinessError;
3807    console.error(`auth exception = code is ${err.code}, message is ${err.message}`);
3808  }
3809  ```
3810
3811### authWithPopup<sup>10+</sup>
3812
3813authWithPopup(callback: IUserAuthCallback): void
3814
3815弹框认证指定的域账号。
3816
3817**系统接口:** 此接口为系统接口。
3818
3819**系统能力:** SystemCapability.Account.OsAccount
3820
3821**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
3822
3823从API version 11开始无需申请权限,建议升级SDK版本。
3824
3825**参数:**
3826
3827| 参数名      | 类型                                    | 必填 | 说明             |
3828| ---------- | --------------------------------------- | ---- | --------------- |
3829| callback   | [IUserAuthCallback](#iuserauthcallback8)  | 是   | 指示认证结果回调。|
3830
3831**错误码:**
3832
3833| 错误码ID | 错误信息                     |
3834| -------- | --------------------------- |
3835| 201 | Permission denied.|
3836| 202 | Not system application.|
3837| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3838| 801 | Capability not supported.|
3839| 12300001 | The system service works abnormally. |
3840| 12300003 | No domain account is bound. |
3841| 12300013 | Network exception. |
3842| 12300101 | Authentication failed. |
3843| 12300109 | The authentication, enrollment, or update operation is canceled. |
3844| 12300110 | The authentication is locked. |
3845| 12300111 | The authentication time out. |
3846| 12300112 | The authentication service is busy. |
3847| 12300113 | The account authentication service does not exist. |
3848| 12300114 | The account authentication service works abnormally. |
3849| 12300211 | Server unreachable. |
3850
3851**示例:**
3852  ```ts
3853  try {
3854    osAccount.DomainAccountManager.authWithPopup({
3855      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3856        console.info('auth resultCode = ' + resultCode);
3857        console.info('auth authResult = ' + JSON.stringify(authResult));
3858      }
3859    })
3860  } catch (err) {
3861    const err = err as BusinessError;
3862    console.error(`auth exception = code is ${err.code}, message is ${err.message}`);
3863  }
3864  ```
3865
3866### authWithPopup<sup>10+</sup>
3867
3868authWithPopup(localId: number, callback: IUserAuthCallback): void
3869
3870弹框认证指定的域账号。
3871
3872**系统接口:** 此接口为系统接口。
3873
3874**系统能力:** SystemCapability.Account.OsAccount
3875
3876**需要权限:** ohos.permission.ACCESS_USER_AUTH_INTERNAL
3877
3878从API version 11开始无需申请权限,建议升级SDK版本。
3879
3880**参数:**
3881
3882| 参数名      | 类型                                    | 必填 | 说明             |
3883| ---------- | --------------------------------------- | ---- | --------------- |
3884| localId   | number  | 是   | 指示绑定域账号的系统账号的本地标识。|
3885| callback   | [IUserAuthCallback](#iuserauthcallback8)  | 是   | 指示认证结果回调。|
3886
3887**错误码:**
3888
3889| 错误码ID | 错误信息                     |
3890| -------- | --------------------------- |
3891| 201 | Permission denied.|
3892| 202 | Not system application.|
3893| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3894| 801 | Capability not supported.|
3895| 12300001 | The system service works abnormally. |
3896| 12300002 | Invalid localId. |
3897| 12300003 | No domain account is bound. |
3898| 12300013 | Network exception. |
3899| 12300101 | Authentication failed. |
3900| 12300109 | The authentication, enrollment, or update operation is canceled. |
3901| 12300110 | The authentication is locked. |
3902| 12300111 | The authentication time out. |
3903| 12300112 | The authentication service is busy. |
3904| 12300113 | The account authentication service does not exist. |
3905| 12300114 | The account authentication service works abnormally. |
3906| 12300211 | Server unreachable. |
3907
3908**示例:**
3909  ```ts
3910  try {
3911    osAccount.DomainAccountManager.authWithPopup(100, {
3912      onResult: (resultCode: number, authResult: osAccount.AuthResult) => {
3913        console.info('authWithPopup resultCode = ' + resultCode);
3914        console.info('authWithPopup authResult = ' + JSON.stringify(authResult));
3915      }
3916    })
3917  } catch (err) {
3918    const err = err as BusinessError;
3919    console.error(`authWithPopup exception = code is ${err.code}, message is ${err.message}`);
3920  }
3921  ```
3922
3923### hasAccount<sup>10+</sup>
3924
3925hasAccount(domainAccountInfo: DomainAccountInfo, callback: AsyncCallback&lt;boolean&gt;): void
3926
3927检查是否存在指定的域账号。
3928
3929**系统接口:** 此接口为系统接口。
3930
3931**系统能力:** SystemCapability.Account.OsAccount
3932
3933**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
3934
3935**参数:**
3936
3937| 参数名      | 类型                                    | 必填 | 说明             |
3938| ---------- | --------------------------------------- | ---- | --------------- |
3939| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3940| callback   | AsyncCallback&lt;boolean&gt;  | 是   | 指示检查结果回调。true表示指定的域账号已存在;false表示指定的域账号不存在。|
3941
3942**错误码:**
3943
3944| 错误码ID | 错误信息                     |
3945| -------- | --------------------------- |
3946| 201 | Permission denied.|
3947| 202 | Not system application.|
3948| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
3949| 801 | Capability not supported.|
3950| 12300001 | The system service works abnormally. |
3951| 12300002 | Invalid domainAccountInfo. |
3952| 12300013 | Network exception. |
3953| 12300014 | Not authenticated. |
3954| 12300111 | The operation time out. |
3955| 12300114 | The authentication service works abnormally. |
3956| 12300211 | Server unreachable. |
3957
3958**示例:**
3959  ```ts
3960  import { BusinessError } from '@kit.BasicServicesKit';
3961  let domainAccountInfo: osAccount.DomainAccountInfo = {
3962    domain: 'CHINA',
3963    accountName: 'zhangsan'
3964  }
3965  try {
3966    osAccount.DomainAccountManager.hasAccount(domainAccountInfo, (err: BusinessError, result: boolean) => {
3967      if (err) {
3968        console.error(`call hasAccount failed, code is ${err.code}, message is ${err.message}`);
3969      } else {
3970        console.info('hasAccount result: ' + result);
3971      }
3972    });
3973  } catch (err) {
3974    const err = err as BusinessError;
3975    console.error(`hasAccount exception = code is ${err.code}, message is ${err.message}`);
3976  }
3977  ```
3978
3979### hasAccount<sup>10+</sup>
3980
3981hasAccount(domainAccountInfo: DomainAccountInfo): Promise&lt;boolean&gt;
3982
3983检查是否存在指定的域账号。
3984
3985**系统接口:** 此接口为系统接口。
3986
3987**系统能力:** SystemCapability.Account.OsAccount
3988
3989**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
3990
3991**参数:**
3992
3993| 参数名      | 类型                                    | 必填 | 说明             |
3994| ---------- | --------------------------------------- | ---- | --------------- |
3995| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
3996
3997**返回值:**
3998
3999| 类型                      | 说明                     |
4000| :------------------------ | ----------------------- |
4001| Promise&lt;boolean&gt; | Promise对象。返回true表示指定的域账号已存在;返回false表示指定的域账号不存在。 |
4002
4003**错误码:**
4004
4005| 错误码ID | 错误信息                     |
4006| -------- | --------------------------- |
4007| 201 | Permission denied.|
4008| 202 | Not system application.|
4009| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4010| 801 | Capability not supported.|
4011| 12300001 | The system service works abnormally. |
4012| 12300002 | Invalid domainAccountInfo. |
4013| 12300013 | Network exception. |
4014| 12300014 | Not authenticated. |
4015| 12300111 | The operation time out. |
4016| 12300114 | The authentication service works abnormally. |
4017| 12300211 | Server unreachable. |
4018
4019**示例:**
4020  ```ts
4021  import { BusinessError } from '@kit.BasicServicesKit';
4022  let domainAccountInfo: osAccount.DomainAccountInfo = {
4023    domain: 'CHINA',
4024    accountName: 'zhangsan'
4025  }
4026  try {
4027    osAccount.DomainAccountManager.hasAccount(domainAccountInfo).then((result: boolean) => {
4028      console.info('hasAccount result: ' + result);
4029    }).catch((err: BusinessError) => {
4030        console.error(`call hasAccount failed, code is ${err.code}, message is ${err.message}`);
4031    });
4032  } catch (err) {
4033    const err = err as BusinessError;
4034    console.error(`hasAccount exception = code is ${err.code}, message is ${err.message}`);
4035  }
4036  ```
4037
4038### updateAccountToken<sup>10+</sup>
4039
4040updateAccountToken(domainAccountInfo: DomainAccountInfo, token: Uint8Array, callback: AsyncCallback&lt;void&gt;): void
4041
4042更新指定域账号的令牌,空令牌表示目标域账号的令牌失效。使用callback异步回调。
4043
4044**系统接口:** 此接口为系统接口。
4045
4046**系统能力:** SystemCapability.Account.OsAccount
4047
4048**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
4049
4050**参数:**
4051
4052| 参数名      | 类型                                    | 必填 | 说明             |
4053| ---------- | --------------------------------------- | ---- | --------------- |
4054| domainAccountInfo | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
4055| token | Uint8Array  | 是   | 指示域账号的令牌。|
4056| callback | AsyncCallback&lt;void&gt; | 是 | 回调函数。如果更新成功,err为null,否则为错误对象。|
4057
4058**错误码:**
4059
4060| 错误码ID | 错误信息                     |
4061| -------- | --------------------------- |
4062| 201 | Permission denied.|
4063| 202 | Not system application.|
4064| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4065| 12300001 | The system service works abnormally. |
4066| 12300002 | Invalid token. |
4067| 12300003 | Account not found. |
4068
4069**示例:**
4070  ```ts
4071  import { BusinessError } from '@kit.BasicServicesKit';
4072  let domainAccountInfo: osAccount.DomainAccountInfo = {
4073    domain: 'CHINA',
4074    accountName: 'zhangsan',
4075    accountId: '123456'
4076  }
4077  let token = new Uint8Array([0])
4078  try {
4079    osAccount.DomainAccountManager.updateAccountToken(domainAccountInfo, token, (err: BusinessError) => {
4080      if (err != null) {
4081        console.error(`updateAccountToken failed, code is ${err.code}, message is ${err.message}`);
4082      } else {
4083        console.info('updateAccountToken successfully');
4084      }
4085    })
4086  } catch (err) {
4087    const err = err as BusinessError;
4088    console.error(`updateAccountToken exception = code is ${err.code}, message is ${err.message}`);
4089  }
4090  ```
4091
4092### updateAccountToken<sup>10+</sup>
4093
4094updateAccountToken(domainAccountInfo: DomainAccountInfo, token: Uint8Array): Promise&lt;void&gt;
4095
4096更新指定域账号的令牌,空令牌表示目标域账号的令牌失效。使用Promise异步回调。
4097
4098**系统接口:** 此接口为系统接口。
4099
4100**系统能力:** SystemCapability.Account.OsAccount
4101
4102**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTS
4103
4104**参数:**
4105
4106| 参数名      | 类型                                    | 必填 | 说明             |
4107| ---------- | --------------------------------------- | ---- | --------------- |
4108| domainAccountInfo | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
4109| token | Uint8Array  | 是   | 指示域账号的令牌。|
4110
4111**返回值:**
4112
4113| 类型                      | 说明                     |
4114| :------------------------ | ----------------------- |
4115| Promise&lt;void&gt; | Promise对象,无返回结果的Promise对象。 |
4116
4117**错误码:**
4118
4119| 错误码ID | 错误信息                     |
4120| -------- | --------------------------- |
4121| 201 | Permission denied.|
4122| 202 | Not system application.|
4123| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4124| 12300001 | The system service works abnormally. |
4125| 12300002 | Invalid token. |
4126| 12300003 | Account not found. |
4127
4128**示例:**
4129  ```ts
4130  import { BusinessError } from '@kit.BasicServicesKit';
4131  let domainAccountInfo: osAccount.DomainAccountInfo = {
4132    domain: 'CHINA',
4133    accountName: 'zhangsan',
4134    accountId: '123456'
4135  }
4136  let token = new Uint8Array([0])
4137  try {
4138    osAccount.DomainAccountManager.updateAccountToken(domainAccountInfo, token).then(() => {
4139      console.info('updateAccountToken successfully');
4140    }).catch((err: BusinessError) => {
4141        console.error(`updateAccountToken failed, code is ${err.code}, message is ${err.message}`);
4142    });
4143  } catch (err) {
4144    const err = err as BusinessError;
4145    console.error(`updateAccountToken exception = code is ${err.code}, message is ${err.message}`);
4146  }
4147  ```
4148
4149### getAccountInfo<sup>10+</sup>
4150
4151getAccountInfo(options: GetDomainAccountInfoOptions, callback: AsyncCallback&lt;DomainAccountInfo&gt;): void
4152
4153查询指定的域账号信息。使用callback异步回调。
4154
4155**系统接口:** 此接口为系统接口。
4156
4157**系统能力:** SystemCapability.Account.OsAccount
4158
4159**需要权限:** ohos.permission.GET_DOMAIN_ACCOUNTS
4160
4161**参数:**
4162
4163| 参数名      | 类型                                    | 必填 | 说明             |
4164| ---------- | --------------------------------------- | ---- | --------------- |
4165| options   | [GetDomainAccountInfoOptions](#getdomainaccountinfooptions10)  | 是   | 指示域账号信息。|
4166| callback   | AsyncCallback&lt;DomainAccountInfo&gt;  | 是   | 指示查询结果回调。|
4167
4168**错误码:**
4169
4170| 错误码ID | 错误信息                     |
4171| -------- | --------------------------- |
4172| 201 | Permission denied.|
4173| 202 | Not system application.|
4174| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4175| 801 | Capability not supported.|
4176| 12300001 | The system service works abnormally. |
4177| 12300003 | Account not found. |
4178| 12300013 | Network exception. |
4179| 12300014 | Not authenticated. |
4180| 12300111 | The operation time out. |
4181| 12300114 | The authentication service works abnormally. |
4182| 12300211 | Server unreachable. |
4183
4184**示例:**
4185  ```ts
4186  import { BusinessError } from '@kit.BasicServicesKit';
4187  let domainAccountInfo: osAccount.GetDomainAccountInfoOptions = {
4188    domain: 'CHINA',
4189    accountName: 'zhangsan'
4190  }
4191  try {
4192    osAccount.DomainAccountManager.getAccountInfo(domainAccountInfo,
4193      (err: BusinessError, result: osAccount.DomainAccountInfo) => {
4194      if (err) {
4195        console.error(`call getAccountInfo failed, code is ${err.code}, message is ${err.message}`);
4196      } else {
4197        console.info('getAccountInfo result: ' + result);
4198      }
4199    });
4200  } catch (err) {
4201    const err = err as BusinessError;
4202    console.error(`getAccountInfo exception = code is ${err.code}, message is ${err.message}`);
4203  }
4204  ```
4205
4206### getAccountInfo<sup>10+</sup>
4207
4208getAccountInfo(options: GetDomainAccountInfoOptions): Promise&lt;DomainAccountInfo&gt;
4209
4210查询指定的域账号信息。使用Promise异步回调。
4211
4212**系统接口:** 此接口为系统接口。
4213
4214**系统能力:** SystemCapability.Account.OsAccount
4215
4216**需要权限:** ohos.permission.GET_DOMAIN_ACCOUNTS
4217
4218**参数:**
4219
4220| 参数名      | 类型                                    | 必填 | 说明             |
4221| ---------- | --------------------------------------- | ---- | --------------- |
4222| options   | [GetDomainAccountInfoOptions](#getdomainaccountinfooptions10)  | 是   | 指示域账号信息。|
4223
4224**返回值:**
4225
4226| 类型                      | 说明                     |
4227| :------------------------ | ----------------------- |
4228| Promise&lt;DomainAccountInfo&gt; | Promise对象,返回指定的域账号信息。 |
4229
4230**错误码:**
4231
4232| 错误码ID | 错误信息                     |
4233| -------- | --------------------------- |
4234| 201 | Permission denied.|
4235| 202 | Not system application.|
4236| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4237| 801 | Capability not supported.|
4238| 12300001 | The system service works abnormally. |
4239| 12300003 | Account not found. |
4240| 12300013 | Network exception. |
4241| 12300014 | Not authenticated. |
4242| 12300111 | The operation time out. |
4243| 12300114 | The authentication service works abnormally. |
4244| 12300211 | Server unreachable. |
4245
4246**示例:**
4247  ```ts
4248  import { BusinessError } from '@kit.BasicServicesKit';
4249  let domainAccountInfo: osAccount.GetDomainAccountInfoOptions = {
4250    domain: 'CHINA',
4251    accountName: 'zhangsan'
4252  }
4253  try {
4254    osAccount.DomainAccountManager.getAccountInfo(domainAccountInfo)
4255      .then((result: osAccount.DomainAccountInfo) => {
4256      console.info('getAccountInfo result: ' + result);
4257    }).catch((err: BusinessError) => {
4258      console.error(`call getAccountInfo failed, code is ${err.code}, message is ${err.message}`);
4259    });
4260  } catch (err) {
4261    const err = err as BusinessError;
4262    console.error(`getAccountInfo exception = code is ${err.code}, message is ${err.message}`);
4263  }
4264  ```
4265
4266### getAccessToken<sup>11+</sup>
4267
4268getAccessToken(businessParams: Record<string, Object>, callback: AsyncCallback&lt;Uint8Array&gt;): void
4269
4270获取当前域账号的业务访问令牌,使用callback异步回调。
4271
4272**系统接口:** 此接口为系统接口。
4273
4274**系统能力:** SystemCapability.Account.OsAccount
4275
4276**参数:**
4277
4278| 参数名      | 类型                                    | 必填 | 说明             |
4279| ---------- | --------------------------------------- | ---- | --------------- |
4280| businessParams | Record<string, Object>  | 是   | 指示业务参数,具体格式取决于域插件的实现要求。|
4281| callback | AsyncCallback&lt;Uint8Array&gt;  | 是   | 指示结果回调。如果获取成功,err返回null,否则为错误对象。|
4282
4283**错误码:**
4284
4285| 错误码ID | 错误信息                     |
4286| -------- | --------------------------- |
4287| 202 | Not system application.|
4288| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4289| 801 | Capability not supported.|
4290| 12300001 | The system service works abnormally. |
4291| 12300002 | Invalid business parameters. |
4292| 12300003 | Domain account not found. |
4293| 12300013 | Network exception. |
4294| 12300014 | The domain account is not authenticated. |
4295| 12300111 | The operation time out. |
4296| 12300114 | The authentication service works abnormally. |
4297| 12300211 | Server unreachable. |
4298
4299**示例:**
4300  ```ts
4301  import { BusinessError } from '@kit.BasicServicesKit';
4302  let businessParams: Record<string, Object> = {
4303    'clientId': 'xxx',
4304    'secretId': 'yyy'
4305  };  // depends on the implementation of the domain plugin
4306  try {
4307    osAccount.DomainAccountManager.getAccessToken(businessParams,
4308      (err: BusinessError, result: Uint8Array) => {
4309      if (err) {
4310        console.error(`getAccessToken failed, code is ${err.code}, message is ${err.message}`);
4311      } else {
4312        console.info('getAccessToken result: ' + result);
4313      }
4314    });
4315  } catch (err) {
4316    const err = err as BusinessError;
4317    console.error(`getAccessToken exception = code is ${err.code}, message is ${err.message}`);
4318  }
4319  ```
4320
4321### getAccessToken<sup>11+</sup>
4322
4323getAccessToken(businessParams: Record<string, Object>): Promise&lt;Uint8Array&gt;
4324
4325查询当前域账号的业务访问令牌,使用promise异步回调。
4326
4327**系统接口:** 此接口为系统接口。
4328
4329**系统能力:** SystemCapability.Account.OsAccount
4330
4331**参数:**
4332
4333| 参数名      | 类型                                    | 必填 | 说明             |
4334| ---------- | --------------------------------------- | ---- | --------------- |
4335| businessParams | Record<string, Object> | 是   | 指示业务参数,具体格式取决于域插件的实现要求。|
4336
4337**返回值:**
4338
4339| 类型                      | 说明                     |
4340| :------------------------ | ----------------------- |
4341| Promise&lt;Uint8Array&gt; | Promise对象,返回业务访问令牌。 |
4342
4343**错误码:**
4344
4345| 错误码ID | 错误信息                     |
4346| -------- | --------------------------- |
4347| 202 | Not system application.|
4348| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4349| 801 | Capability not supported.|
4350| 12300001 | The system service works abnormally. |
4351| 12300002 | Invalid business parameters. |
4352| 12300003 | Domain account not found. |
4353| 12300013 | Network exception. |
4354| 12300014 | The domain account is not authenticated. |
4355| 12300111 | The operation time out. |
4356| 12300114 | The authentication service works abnormally. |
4357| 12300211 | Server unreachable. |
4358
4359**示例:**
4360  ```ts
4361  import { BusinessError } from '@kit.BasicServicesKit';
4362  let businessParams: Record<string, Object> = {
4363    'clientId': 'xxx',
4364    'secretId': 'yyy'
4365  };  // depends on the implementation of the domain plugin
4366  try {
4367    osAccount.DomainAccountManager.getAccessToken(businessParams)
4368      .then((result: Uint8Array) => {
4369      console.info('getAccessToken result: ' + result);
4370    }).catch((err: BusinessError) => {
4371      console.error(`getAccessToken failed, code is ${err.code}, message is ${err.message}`);
4372    });
4373  } catch (err) {
4374    const err = err as BusinessError;
4375    console.error(`getAccessToken exception = code is ${err.code}, message is ${err.message}`);
4376  }
4377  ```
4378
4379### isAuthenticationExpired<sup>12+</sup>
4380
4381isAuthenticationExpired(domainAccountInfo: DomainAccountInfo): Promise&lt;boolean&gt;;
4382
4383判断指定域账号是否登录超期。使用Promise异步回调。
4384
4385**系统接口:** 此接口为系统接口。
4386
4387**需要权限:** ohos.permission.MANAGE_LOCAL_ACCOUNTSohos.permission.INTERACT_ACROSS_LOCAL_ACCOUNTS
4388
4389**系统能力:** SystemCapability.Account.OsAccount
4390
4391**参数:**
4392
4393| 参数名      | 类型                                    | 必填 | 说明             |
4394| ---------- | --------------------------------------- | ---- | --------------- |
4395| domainAccountInfo   | [DomainAccountInfo](#domainaccountinfo8)  | 是   | 指示域账号信息。|
4396
4397**返回值:**
4398
4399| 类型                      | 说明                     |
4400| :------------------------ | ----------------------- |
4401| Promise&lt;boolean&gt; | Promise对象。返回true表示指定的域账号已登录超期;返回false表示指定的域账号未登录超期。 |
4402
4403**错误码:**
4404
4405| 错误码ID | 错误信息                     |
4406| -------- | --------------------------- |
4407| 201 | Permission denied.|
4408| 202 | Not system application.|
4409| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4410| 801 | Capability not supported.|
4411| 12300001 | The system service works abnormally. |
4412| 12300003 | Domain account not found. |
4413
4414**示例:**
4415  ```ts
4416  import { BusinessError } from '@kit.BasicServicesKit';
4417  let domainInfo: osAccount.DomainAccountInfo =
4418    {domain: 'testDomain', accountName: 'testAccountName'};
4419  try {
4420    osAccount.DomainAccountManager.isAuthenticationExpired(domainInfo).then((result: boolean) => {
4421      console.info('isAuthenticationExpired, result: ' + result);
4422    }).catch((err: BusinessError) => {
4423      console.error('isAuthenticationExpired err: ' + err);
4424    });
4425  } catch (e) {
4426    const err = e as BusinessError;
4427    console.error('isAuthenticationExpired exception: ' + e);
4428  }
4429  ```
4430
4431## UserIdentityManager<sup>8+</sup>
4432
4433获取用户身份管理类。
4434
4435**系统接口:** 此接口为系统接口。
4436
4437### constructor<sup>8+</sup>
4438
4439constructor()
4440
4441用户身份管理类的默认构造函数。
4442
4443**系统接口:** 此接口为系统接口。
4444
4445**系统能力:** SystemCapability.Account.OsAccount
4446
4447**错误码:**
4448
4449| 错误码ID | 错误信息                     |
4450| -------- | --------------------------- |
4451| 202 | Not system application.|
4452
4453**示例:**
4454  ```ts
4455  let userIDM = new osAccount.UserIdentityManager();
4456  ```
4457
4458### openSession<sup>8+</sup>
4459
4460openSession(callback: AsyncCallback&lt;Uint8Array&gt;): void
4461
4462打开会话,获取挑战值。使用callback异步回调。
4463
4464**系统接口:** 此接口为系统接口。
4465
4466**系统能力:** SystemCapability.Account.OsAccount
4467
4468**需要权限:** ohos.permission.MANAGE_USER_IDM
4469
4470**参数:**
4471
4472| 参数名    | 类型                             | 必填 | 说明                                                            |
4473| -------- | -------------------------------- | ---- | -------------------------------------------------------------- |
4474| callback | AsyncCallback&lt;Uint8Array&gt;  | 是   | 回调函数。如果打开会话成功,err为null,data为挑战值;否则为错误对象。|
4475
4476**错误码:**
4477
4478| 错误码ID | 错误信息                     |
4479| -------- | --------------------------- |
4480| 201 | Permission denied.|
4481| 202 | Not system application.|
4482| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4483| 12300001 | The system service works abnormally. |
4484
4485**示例:**
4486  ```ts
4487  import { BusinessError } from '@kit.BasicServicesKit';
4488  let userIDM = new osAccount.UserIdentityManager();
4489  try {
4490    userIDM.openSession((err: BusinessError, challenge: Uint8Array) => {
4491      if (err) {
4492        console.error(`openSession exception = code is ${err.code}, message is ${err.message}`);
4493      } else {
4494        console.info('openSession challenge = ' + JSON.stringify(challenge));
4495      }
4496    });
4497  } catch (e) {
4498    const err = e as BusinessError;
4499    console.error(`openSession exception = code is ${err.code}, message is ${err.message}`);
4500  }
4501  ```
4502
4503### openSession<sup>8+</sup>
4504
4505openSession(accountId?: number): Promise&lt;Uint8Array&gt;
4506
4507打开会话,获取挑战值(用于判断后续的身份认证场景是否处于该会话下,防止重放攻击)。使用Promise异步回调。
4508
4509**系统接口:** 此接口为系统接口。
4510
4511**系统能力:** SystemCapability.Account.OsAccount
4512
4513**需要权限:** ohos.permission.MANAGE_USER_IDM
4514
4515**参数:**
4516
4517| 参数名     | 类型    | 必填 | 说明        |
4518| --------- | ------- | ---- | ----------- |
4519| accountId<sup>12+</sup> | number  | 否   | 系统账号标识,默认为空。 |
4520
4521**返回值:**
4522
4523| 类型                      | 说明                     |
4524| :------------------------ | ----------------------- |
4525| Promise&lt;Uint8Array&gt; | Promise对象,返回挑战值。 |
4526
4527**错误码:**
4528
4529| 错误码ID | 错误信息                     |
4530| -------- | --------------------------- |
4531| 201 | Permission denied.|
4532| 202 | Not system application.|
4533| 401 | Parameter error. Possible causes: Incorrect parameter types. |
4534| 12300001 | The system service works abnormally. |
4535| 12300003 | Account not found. |
4536| 12300008 | Restricted account. |
4537
4538**示例:**
4539  ```ts
4540  import { BusinessError } from '@kit.BasicServicesKit';
4541  let userIDM = new osAccount.UserIdentityManager();
4542  let accountId = 100;
4543  try {
4544    userIDM.openSession(accountId).then((challenge: Uint8Array) => {
4545        console.info('openSession challenge = ' + JSON.stringify(challenge));
4546    }).catch((err: BusinessError) => {
4547        console.error(`openSession error = code is ${err.code}, message is ${err.message}`);
4548    });
4549  } catch (e) {
4550    const err = e as BusinessError;
4551    console.error(`openSession exception = code is ${err.code}, message is ${err.message}`);
4552  }
4553  ```
4554
4555### addCredential<sup>8+</sup>
4556
4557addCredential(credentialInfo: CredentialInfo, callback: IIdmCallback): void
4558
4559添加凭据,添加用户凭据信息,传入凭据添加方法和凭据信息(凭据类型,子类,如果添加用户的非密码凭据,则传入密码身份验证令牌),并获取结果/获取信息。
4560
4561**系统接口:** 此接口为系统接口。
4562
4563**系统能力:** SystemCapability.Account.OsAccount
4564
4565**需要权限:** ohos.permission.MANAGE_USER_IDM
4566
4567**参数:**
4568
4569| 参数名           | 类型                                 | 必填 | 说明                        |
4570| --------------- | ------------------------------------ | --- | ---------------------------- |
4571| credentialInfo  | [CredentialInfo](#credentialinfo8)   | 是  | 指示凭据信息。                |
4572| callback        | [IIdmCallback](#iidmcallback8)       | 是  | 回调对象,返回添加凭据的结果。  |
4573
4574**错误码:**
4575
4576| 错误码ID | 错误信息                     |
4577| -------- | ------------------- |
4578| 201 | Permission denied.|
4579| 202 | Not system application.|
4580| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4581| 12300001 | The system service works abnormally. |
4582| 12300002 | Invalid credentialInfo, i.e. authType or authSubType. |
4583| 12300003 | Account not found. |
4584| 12300008 | Restricted account. |
4585| 12300101 | The token is invalid. |
4586| 12300106 | The authentication type is not supported. |
4587| 12300109 | The authentication, enrollment, or update operation is canceled. |
4588| 12300111 | The operation time out. |
4589| 12300115 | The number of credentials reaches the upper limit. |
4590| 12300116 | Credential complexity verification failed. |
4591
4592**示例:**
4593  ```ts
4594  import { BusinessError } from '@kit.BasicServicesKit';
4595  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
4596  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
4597  pinAuth.registerInputer({
4598    onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
4599      callback.onSetData(authSubType, password);
4600    }
4601  });
4602  let credentialInfo: osAccount.CredentialInfo = {
4603    credType: osAccount.AuthType.PIN,
4604    credSubType: osAccount.AuthSubType.PIN_SIX,
4605    token: new Uint8Array([]),
4606  };
4607  let userIDM = new osAccount.UserIdentityManager();
4608  userIDM.openSession((err: BusinessError, challenge: Uint8Array) => {
4609    try {
4610    userIDM.addCredential(credentialInfo, {
4611      onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4612        console.info('addCredential result = ' + result);
4613        console.info('addCredential extraInfo = ' + extraInfo);
4614      }
4615    });
4616    } catch (e) {
4617    const err = e as BusinessError;
4618      console.error(`addCredential exception = code is ${err.code}, message is ${err.message}`);
4619    }
4620  });
4621  ```
4622
4623### updateCredential<sup>8+</sup>
4624
4625updateCredential(credentialInfo: CredentialInfo, callback: IIdmCallback): void
4626
4627更新凭据。使用callback异步回调。
4628
4629**系统接口:** 此接口为系统接口。
4630
4631**系统能力:** SystemCapability.Account.OsAccount
4632
4633**需要权限:** ohos.permission.MANAGE_USER_IDM
4634
4635**参数:**
4636
4637| 参数名           | 类型                                  | 必填 | 说明                     |
4638| --------------- | ------------------------------------- | --- | ------------------------- |
4639| credentialInfo  | [CredentialInfo](#credentialinfo8)    | 是  | 指示凭据信息。             |
4640| callback        | [IIdmCallback](#iidmcallback8)        | 是  | 回调对象,返回更新凭据的结果。 |
4641
4642**错误码:**
4643
4644| 错误码ID | 错误信息                     |
4645| -------- | ------------------- |
4646| 201 | Permission denied.|
4647| 202 | Not system application.|
4648| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4649| 12300001 | The system service works abnormally. |
4650| 12300002 | Invalid credentialInfo, i.e. authType or authSubType. |
4651| 12300003 | Account not found. |
4652| 12300101 | The token is invalid. |
4653| 12300102 | The credential does not exist. |
4654| 12300106 | The authentication type is not supported. |
4655| 12300109 | The authentication, enrollment, or update operation is canceled. |
4656| 12300111 | The operation time out. |
4657| 12300116 | Credential complexity verification failed. |
4658
4659**示例:**
4660  ```ts
4661  import { BusinessError } from '@kit.BasicServicesKit';
4662  let userIDM = new osAccount.UserIdentityManager();
4663  let userAuth: osAccount.UserAuth = new osAccount.UserAuth();
4664  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
4665  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
4666  let credentialInfo: osAccount.CredentialInfo = {
4667    credType: osAccount.AuthType.PIN,
4668    credSubType: osAccount.AuthSubType.PIN_SIX,
4669    token: new Uint8Array([]),
4670  };
4671  pinAuth.registerInputer({
4672    onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
4673      callback.onSetData(authSubType, password);
4674    }
4675  });
4676  userIDM.openSession((err: BusinessError, challenge: Uint8Array) => {
4677    userAuth.auth(challenge, credentialInfo.credType, osAccount.AuthTrustLevel.ATL1, {
4678      onResult: (result: number, extraInfo: osAccount.AuthResult) => {
4679        if (result != osAccount.ResultCode.SUCCESS) {
4680          return;
4681        }
4682        if (extraInfo.token != null) {
4683          credentialInfo.token = extraInfo.token;
4684        }
4685        try {
4686          userIDM.updateCredential(credentialInfo, {
4687            onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4688                console.info('updateCredential result = ' + result);
4689                console.info('updateCredential extraInfo = ' + extraInfo);
4690            }
4691          });
4692        } catch (e) {
4693    const err = e as BusinessError;
4694          console.error(`updateCredential exception = code is ${err.code}, message is ${err.message}`);
4695        }
4696      }
4697    });
4698  });
4699  ```
4700
4701### closeSession<sup>8+</sup>
4702
4703closeSession(accountId?: number): void
4704
4705关闭会话,结束IDM操作。
4706
4707**系统接口:** 此接口为系统接口。
4708
4709**系统能力:** SystemCapability.Account.OsAccount
4710
4711**需要权限:** ohos.permission.MANAGE_USER_IDM
4712
4713**参数:**
4714
4715| 参数名     | 类型    | 必填 | 说明        |
4716| --------- | ------- | ---- | ----------- |
4717| accountId<sup>12+</sup> | number  | 否   | 系统账号标识,默认为空。 |
4718
4719**错误码:**
4720
4721| 错误码ID | 错误信息                     |
4722| -------- | --------------------------- |
4723| 201 | Permission denied.|
4724| 202 | Not system application.|
4725| 401 | Parameter error. Possible causes: Incorrect parameter types. |
4726| 12300001 | The system service works abnormally. |
4727| 12300003 | Account not found. |
4728| 12300008 | Restricted account. |
4729
4730**示例:**
4731  ```ts
4732  let userIDM = new osAccount.UserIdentityManager();
4733  let accountId = 100;
4734  userIDM.closeSession(accountId);
4735  ```
4736
4737### cancel<sup>8+</sup>
4738
4739cancel(challenge: Uint8Array): void
4740
4741根据挑战值取消条目。
4742
4743**系统接口:** 此接口为系统接口。
4744
4745**系统能力:** SystemCapability.Account.OsAccount
4746
4747**需要权限:** ohos.permission.MANAGE_USER_IDM
4748
4749**参数:**
4750
4751| 参数名    | 类型        | 必填 | 说明   |
4752| -------- | ----------- | ---- | ----- |
4753| challenge | Uint8Array | 是   | 挑战值。 |
4754
4755**错误码:**
4756
4757| 错误码ID | 错误信息            |
4758| -------- | ------------------- |
4759| 201 | Permission denied.|
4760| 202 | Not system application.|
4761| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4762| 12300001 | The system service works abnormally. |
4763| 12300002 | Invalid challenge. |
4764
4765**示例:**
4766  ```ts
4767  let userIDM = new osAccount.UserIdentityManager();
4768  let challenge: Uint8Array = new Uint8Array([0]);
4769  try {
4770    userIDM.cancel(challenge);
4771  } catch(err) {
4772    console.error(`cancel code is ${err.code}, message is ${err.message}`);
4773  }
4774  ```
4775
4776### delUser<sup>8+</sup>
4777
4778delUser(token: Uint8Array, callback: IIdmCallback): void
4779
4780删除具有身份验证令牌的用户,使用callback方式异步返回结果。
4781
4782**系统接口:** 此接口为系统接口。
4783
4784**系统能力:** SystemCapability.Account.OsAccount
4785
4786**需要权限:** ohos.permission.MANAGE_USER_IDM
4787
4788**参数:**
4789
4790| 参数名    | 类型                           | 必填 | 说明                      |
4791| -------- | ------------------------------ | --- | ------------------------- |
4792| token    | Uint8Array                     | 是  | 身份验证令牌。             |
4793| callback | [IIdmCallback](#iidmcallback8) | 是  | 回调对象,返回删除用户的结果。|
4794
4795**错误码:**
4796
4797| 错误码ID | 错误信息        |
4798| -------- | ------------------- |
4799| 201 | Permission denied.|
4800| 202 | Not system application.|
4801| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4802| 12300001 | The system service works abnormally. |
4803| 12300101 | The token is invalid. |
4804
4805**示例:**
4806  ```ts
4807  let userIDM = new osAccount.UserIdentityManager();
4808  let token: Uint8Array = new Uint8Array([0]);
4809  try {
4810    userIDM.delUser(token, {
4811      onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4812        console.info('delUser result = ' + result);
4813        console.info('delUser extraInfo = ' + JSON.stringify(extraInfo));
4814      }
4815    });
4816  } catch (e) {
4817    const err = e as BusinessError;
4818    console.error(`delUser exception = code is ${err.code}, message is ${err.message}`);
4819  }
4820  ```
4821
4822### delCred<sup>8+</sup>
4823
4824delCred(credentialId: Uint8Array, token: Uint8Array, callback: IIdmCallback): void
4825
4826删除用户凭据信息。
4827
4828**系统接口:** 此接口为系统接口。
4829
4830**系统能力:** SystemCapability.Account.OsAccount
4831
4832**需要权限:** ohos.permission.MANAGE_USER_IDM
4833
4834**参数:**
4835
4836| 参数名           | 类型                                            | 必填 | 说明                      |
4837| --------------- | ----------------------------------- | --- | ---------------------------|
4838| credentialId    | Uint8Array                          | 是  | 凭证索引。                  |
4839| token           | Uint8Array                          | 是  | 身份验证令牌。               |
4840| callback        | [IIdmCallback](#iidmcallback8)      | 是  | 回调对象,返回删除凭据的结果。 |
4841
4842**错误码:**
4843
4844| 错误码ID | 错误信息             |
4845| -------- | ------------------- |
4846| 201 | Permission denied.|
4847| 202 | Not system application.|
4848| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4849| 12300001 | The system service works abnormally. |
4850| 12300002 | Invalid credentialId. |
4851| 12300101 | The token is invalid. |
4852| 12300102 | The credential does not exist. |
4853
4854**示例:**
4855  ```ts
4856  let userIDM = new osAccount.UserIdentityManager();
4857  let credentialId: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0]);
4858  let token: Uint8Array = new Uint8Array([0]);
4859  try {
4860    userIDM.delCred(credentialId, token, {
4861      onResult: (result: number, extraInfo: osAccount.RequestResult) => {
4862          console.info('delCred result = ' + result);
4863          console.info('delCred extraInfo = ' + JSON.stringify(extraInfo));
4864      }
4865    });
4866  } catch (e) {
4867    const err = e as BusinessError;
4868    console.error(`delCred exception = code is ${err.code}, message is ${err.message}`);
4869  }
4870  ```
4871
4872### getAuthInfo<sup>8+</sup>
4873
4874getAuthInfo(callback: AsyncCallback&lt;Array&lt;EnrolledCredInfo&gt;&gt;): void
4875
4876获取认证信息。使用callback异步回调。
4877
4878**系统接口:** 此接口为系统接口。
4879
4880**系统能力:** SystemCapability.Account.OsAccount
4881
4882**需要权限:** ohos.permission.USE_USER_IDM
4883
4884**参数:**
4885
4886| 参数名    | 类型                                                                     | 必填 | 说明                                                 |
4887| -------- | ------------------------------------------------------------------------ | ---- | --------------------------------------------- |
4888| callback | AsyncCallback&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | 是   | 回调函数。如果成功,err为null,data为当前用户的所有已注册凭据信息;否则为错误对象。|
4889
4890**错误码:**
4891
4892| 错误码ID | 错误信息               |
4893| -------- | --------------------- |
4894| 201 | Permission denied.|
4895| 202 | Not system application.|
4896| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4897| 12300001 | The system service works abnormally. |
4898
4899**示例:**
4900  ```ts
4901  import { BusinessError } from '@kit.BasicServicesKit';
4902  let userIDM = new osAccount.UserIdentityManager();
4903  try {
4904    userIDM.getAuthInfo((err: BusinessError, result: osAccount.EnrolledCredInfo[]) => {
4905      if (err) {
4906        console.error(`getAuthInfo exception = code is ${err.code}, message is ${err.message}`);
4907      } else {
4908        console.info('getAuthInfo result = ' + JSON.stringify(result));
4909      }
4910    });
4911  } catch (e) {
4912    const err = e as BusinessError;
4913    console.error(`getAuthInfo exception = code is ${err.code}, message is ${err.message}`);
4914  }
4915  ```
4916
4917### getAuthInfo<sup>8+</sup>
4918
4919getAuthInfo(authType: AuthType, callback: AsyncCallback&lt;Array&lt;EnrolledCredInfo&gt;&gt;): void
4920
4921获取指定类型的认证信息。使用callback异步回调。
4922
4923**系统接口:** 此接口为系统接口。
4924
4925**系统能力:** SystemCapability.Account.OsAccount
4926
4927**需要权限:** ohos.permission.USE_USER_IDM
4928
4929**参数:**
4930
4931| 参数名    | 类型                                               | 必填 | 说明                                                |
4932| -------- | -------------------------------------------------- | ---- | -------------------------------------------------- |
4933| authType | [AuthType](#authtype8) | 是   | 认证类型。                                          |
4934| callback | AsyncCallback&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | 是   | 回调函数,如果获取成功,err为null,data为当前用户指定类型的所有已注册凭据信息;否则为错误对象。 |
4935
4936**错误码:**
4937
4938| 错误码ID | 错误信息               |
4939| -------- | ------------------- |
4940| 201 | Permission denied.|
4941| 202 | Not system application.|
4942| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
4943| 12300001 | The system service works abnormally. |
4944| 12300002 | Invalid authType. |
4945
4946**示例:**
4947  ```ts
4948  import { BusinessError } from '@kit.BasicServicesKit';
4949  let userIDM = new osAccount.UserIdentityManager();
4950  try {
4951    userIDM.getAuthInfo(osAccount.AuthType.PIN,
4952      (err: BusinessError, result: osAccount.EnrolledCredInfo[]) => {
4953      if (err) {
4954        console.error(`getAuthInfo exception = code is ${err.code}, message is ${err.message}`);
4955      } else {
4956        console.info('getAuthInfo result = ' + JSON.stringify(result));
4957      }
4958    });
4959  } catch (e) {
4960    const err = e as BusinessError;
4961    console.error(`getAuthInfo exception = code is ${err.code}, message is ${err.message}`);
4962  }
4963  ```
4964
4965### getAuthInfo<sup>8+</sup>
4966
4967getAuthInfo(authType?: AuthType): Promise&lt;Array&lt;EnrolledCredInfo&gt;&gt;;
4968
4969获取认证信息。使用Promise异步回调。
4970
4971**系统接口:** 此接口为系统接口。
4972
4973**系统能力:** SystemCapability.Account.OsAccount
4974
4975**需要权限:** ohos.permission.USE_USER_IDM
4976
4977**参数:**
4978
4979| 参数名    | 类型                                | 必填 | 说明      |
4980| -------- | ----------------------------------- | ---- | -------- |
4981| authType | [AuthType](#authtype8)              | 否   | 认证类型,默认为空,表示查询所有认证类型的信息。|
4982
4983**返回值:**
4984
4985| 类型                                         | 说明                                                                     |
4986| :------------------------------------------- | :----------------------------------------------------------------------- |
4987| Promise&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | Promise对象,返回当前用户指定类型的所有已注册凭据信息。|
4988
4989**错误码:**
4990
4991| 错误码ID | 错误信息               |
4992| -------- | ------------------- |
4993| 201 | Permission denied.|
4994| 202 | Not system application.|
4995| 401 | Parameter error. Possible causes: Incorrect parameter types. |
4996| 12300001 | The system service works abnormally. |
4997| 12300002 | Invalid authType. |
4998
4999**示例:**
5000  ```ts
5001  import { BusinessError } from '@kit.BasicServicesKit';
5002  let userIDM = new osAccount.UserIdentityManager();
5003  try {
5004    userIDM.getAuthInfo(osAccount.AuthType.PIN).then((result: osAccount.EnrolledCredInfo[]) => {
5005      console.info('getAuthInfo result = ' + JSON.stringify(result))
5006    }).catch((err: BusinessError) => {
5007      console.error(`getAuthInfo error = code is ${err.code}, message is ${err.message}`);
5008    });
5009  } catch (e) {
5010    const err = e as BusinessError;
5011    console.error(`getAuthInfo exception = code is ${err.code}, message is ${err.message}`);
5012  }
5013  ```
5014
5015### getAuthInfo<sup>12+</sup>
5016
5017getAuthInfo(options?: GetAuthInfoOptions): Promise&lt;Array&lt;EnrolledCredInfo&gt;&gt;
5018
5019依据提供的可选参数,获取认证信息。使用Promise异步回调。
5020
5021**系统接口:** 此接口为系统接口。
5022
5023**系统能力:** SystemCapability.Account.OsAccount
5024
5025**需要权限:** ohos.permission.USE_USER_IDM
5026
5027**参数:**
5028
5029| 参数名    | 类型                                | 必填 | 说明      |
5030| -------- | ----------------------------------- | ---- | -------- |
5031| options | [GetAuthInfoOptions](#getauthinfooptions12)          | 否   | 获取认证信息的可选参数集合。默认为空,表示查询当前用户所有已注册凭据信息。 |
5032
5033**返回值:**
5034
5035| 类型                                         | 说明                                                                     |
5036| :------------------------------------------- | :----------------------------------------------------------------------- |
5037| Promise&lt;Array&lt;[EnrolledCredInfo](#enrolledcredinfo8)&gt;&gt; | Promise对象,返回当前用户指定类型的所有已注册凭据信息。|
5038
5039**错误码:**
5040
5041| 错误码ID | 错误信息               |
5042| -------- | ------------------- |
5043| 201 | Permission denied.|
5044| 202 | Not system application.|
5045| 401 | Parameter error. Possible causes: Incorrect parameter types. |
5046| 12300001 | The system service works abnormally. |
5047| 12300002 | Invalid options. |
5048| 12300003 | Account not found. |
5049
5050**示例:**
5051  ```ts
5052  import { BusinessError } from '@kit.BasicServicesKit';
5053  let userIDM = new osAccount.UserIdentityManager();
5054  let options: osAccount.GetAuthInfoOptions = {
5055    authType: osAccount.AuthType.PIN,
5056    accountId: 100,
5057  };
5058  try {
5059    userIDM.getAuthInfo(options).then((result: osAccount.EnrolledCredInfo[]) => {
5060      console.info('getAuthInfo result = ' + JSON.stringify(result))
5061    }).catch((err: BusinessError) => {
5062      console.error(`getAuthInfo error = code is ${err.code}, message is ${err.message}`);
5063    });
5064  } catch (e) {
5065    const err = e as BusinessError;
5066    console.error(`getAuthInfo exception = code is ${err.code}, message is ${err.message}`);
5067  }
5068  ```
5069
5070### getEnrolledId<sup>12+</sup>
5071
5072getEnrolledId(authType: AuthType, accountId?: number): Promise&lt;Uint8Array&gt;
5073
5074基于凭据类型,以及可选的账号标识,获取已注册的凭据ID。使用Promise异步回调。
5075
5076**系统接口:** 此接口为系统接口。
5077
5078**系统能力:** SystemCapability.Account.OsAccount
5079
5080**需要权限:** ohos.permission.USE_USER_IDM
5081
5082**参数:**
5083
5084| 参数名     | 类型                   | 必填 | 说明      |
5085| --------  | ---------------------- | ---- | -------- |
5086| authType  | [AuthType](#authtype8) | 是   | 认证凭据类型 |
5087| accountId | number                 | 否   | 系统账号标识,默认为空。 |
5088
5089**返回值:**
5090
5091| 类型                       | 说明                                                                     |
5092| :------------------------ | :----------------------------------------------------------------------- |
5093| Promise&lt;Uint8Array&gt; | Promise对象,返回已注册的凭据ID。|
5094
5095**错误码:**
5096
5097| 错误码ID | 错误信息               |
5098| -------- | ------------------- |
5099| 201 | Permission denied.|
5100| 202 | Not system application.|
5101| 401      | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified; 2. Incorrect parameter types. |
5102| 12300001 | The system service works abnormally. |
5103| 12300002 | Invalid authType. |
5104| 12300003 | Account not found. |
5105| 12300102 | The credential does not exist. |
5106| 12300106 | The authentication type is not supported. |
5107
5108**示例:**
5109  ```ts
5110  import { BusinessError } from '@kit.BasicServicesKit';
5111  let userIDM = new osAccount.UserIdentityManager();
5112  let authType: osAccount.AuthType = osAccount.AuthType.PIN;
5113  let accountId = 100;
5114  try {
5115    userIDM.getEnrolledId(authType, accountId).then((enrolledId: Uint8Array) => {
5116        console.info('getEnrolledId enrolledId = ' + JSON.stringify(enrolledId));
5117    }).catch((err: BusinessError) => {
5118        console.error(`getEnrolledId error = code is ${err.code}, message is ${err.message}`);
5119    });
5120  } catch (e) {
5121    const err = e as BusinessError;
5122    console.error(`getEnrolledId exception = code is ${err.code}, message is ${err.message}`);
5123  }
5124  ```
5125
5126## IInputData<sup>8+</sup>
5127
5128密码数据回调。
5129
5130**系统接口:** 此接口为系统接口。
5131
5132### onSetData<sup>8+</sup>
5133
5134onSetData: (authSubType: AuthSubType, data: Uint8Array) => void;
5135
5136**系统接口:** 此接口为系统接口。
5137
5138通知设置数据。
5139
5140**系统能力:** SystemCapability.Account.OsAccount
5141
5142**参数:**
5143
5144| 参数名      | 类型                                     | 必填 | 说明                                            |
5145| ---------- | ---------------------------------------- | ---- | ----------------------------------------------- |
5146| authSubType | [AuthSubType](#authsubtype8)             | 是   | 用于认证的凭据子类型。                            |
5147| data       | Uint8Array                               | 是   | 要设置的数据是凭据,用来在认证、添加、修改凭据操作。 |
5148
5149**错误码:**
5150
5151| 错误码ID | 错误信息               |
5152| -------- | ------------------- |
5153| 202 | Not system application.|
5154| 401 | Parameter error. Possible causes: 1. Mandatory parameters are left unspecified. 2. Incorrect parameter types. |
5155| 12300002 | Invalid pinSubType. |
5156
5157**示例:**
5158  ```ts
5159  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
5160  let passwordNumber: Uint8Array = new Uint8Array([1, 2, 3, 4]);
5161  let inputer: osAccount.IInputer = {
5162    onGetData: (authSubType: osAccount.AuthSubType, callback: osAccount.IInputData) => {
5163        if (authSubType == osAccount.AuthSubType.PIN_NUMBER) {
5164          callback.onSetData(authSubType, passwordNumber);
5165        } else {
5166          callback.onSetData(authSubType, password);
5167        }
5168    }
5169  };
5170  ```
5171
5172## IInputer<sup>8+</sup>
5173
5174凭据输入器回调。
5175
5176**系统接口:** 此接口为系统接口。
5177
5178### onGetData<sup>8+</sup>
5179
5180onGetData: (authSubType: AuthSubType, callback: IInputData, options: GetInputDataOptions) => void;
5181
5182通知调用者获取数据的回调函数。
5183
5184**系统接口:** 此接口为系统接口。
5185
5186**系统能力:** SystemCapability.Account.OsAccount
5187
5188**参数:**
5189
5190| 参数名      | 类型                                    | 必填 | 说明             |
5191| ---------- | --------------------------------------- | ---- | --------------- |
5192| authSubType | [AuthSubType](#authsubtype8) | 是 | 认证凭据子类型。 |
5193| callback   | [IInputData](#iinputdata8)  | 是   | 指示密码数据回调。|
5194| options | [GetInputDataOptions](#getinputdataoptions12) | 是 | 回调函数的可选参数集合。 |
5195
5196**示例:**
5197  ```ts
5198  let password: Uint8Array = new Uint8Array([0, 0, 0, 0, 0, 0]);
5199  let passwordNumber: Uint8Array = new Uint8Array([1, 2, 3, 4]);
5200  let inputer: osAccount.IInputer = {
5201    onGetData: (authSubType: osAccount.AuthSubType,
5202      callback: osAccount.IInputData, options: osAccount.GetInputDataOptions) => {
5203        if (authSubType == osAccount.AuthSubType.PIN_NUMBER) {
5204          callback.onSetData(authSubType, passwordNumber);
5205        } else {
5206          callback.onSetData(authSubType, password);
5207        }
5208    }
5209  };
5210  let pinAuth: osAccount.PINAuth = new osAccount.PINAuth();
5211  let result = pinAuth.registerInputer(inputer);
5212  console.info('registerInputer result: ' + result);
5213  ```
5214
5215## IUserAuthCallback<sup>8+</sup>
5216
5217表示用户认证回调类。
5218
5219**系统接口:** 此接口为系统接口。
5220
5221### onResult<sup>8+</sup>
5222
5223onResult: (result: number, extraInfo: AuthResult) => void;
5224
5225身份认证结果回调函数,返回结果码和认证结果信息。
5226
5227**系统接口:** 此接口为系统接口。
5228
5229**系统能力:** SystemCapability.Account.OsAccount
5230
5231**参数:**
5232
5233| 参数名     | 类型                                    | 必填 | 说明                 |
5234| --------- | --------------------------------------- | ---- | ------------------- |
5235| result    | number                                   | 是   | 表示身份认证结果代码。|
5236| extraInfo | [AuthResult](#authresult8)  | 是   | 表示不同情况下的具体信息,如果认证通过,则在extrainfo中返回认证令牌,如果身份验证失败,则在extrainfo中返回剩余的身份验证时间,如果身份验证执行器被锁定,冻结时间将在extrainfo中返回。|
5237
5238**示例:**
5239  ```ts
5240  let authCallback: osAccount.IUserAuthCallback = {
5241    onResult: (result: number, extraInfo: osAccount.AuthResult) => {
5242      console.info('auth result = ' + result);
5243      console.info('auth extraInfo = ' + JSON.stringify(extraInfo));
5244    }
5245  };
5246  ```
5247
5248### onAcquireInfo?<sup>8+</sup>
5249
5250onAcquireInfo?: (module: number, acquire: number, extraInfo: Uint8Array) => void;
5251
5252身份认证信息获取回调函数。
5253
5254**系统接口:** 此接口为系统接口。
5255
5256**系统能力:** SystemCapability.Account.OsAccount
5257
5258**参数:**
5259
5260| 参数名    | 类型     | 必填 | 说明                           |
5261| --------- | ------- | ---- | ----------------------------- |
5262| module    | number  | 是   | 指示用于身份验证的执行器类型。   |
5263| acquire   | number  | 是   | 指示不同身份验证执行器的tip代码。|
5264| extraInfo | Uint8Array     | 是   | 保留参数。                     |
5265
5266**示例:**
5267  ```ts
5268  let authCallback: osAccount.IUserAuthCallback = {
5269    onResult: (result: number, extraInfo: osAccount.AuthResult) => {
5270      console.info('auth result = ' + result)
5271      console.info('auth extraInfo = ' + JSON.stringify(extraInfo));
5272    },
5273    onAcquireInfo: (module: number, acquire: number, extraInfo: Uint8Array) => {
5274      console.info('auth module = ' + module);
5275      console.info('auth acquire = ' + acquire);
5276      console.info('auth extraInfo = ' + JSON.stringify(extraInfo));
5277    }
5278  };
5279  ```
5280
5281## IIdmCallback<sup>8+</sup>
5282
5283表示身份管理回调类。
5284
5285**系统接口:** 此接口为系统接口。
5286
5287### onResult<sup>8+</sup>
5288
5289onResult: (result: number, extraInfo: RequestResult) => void;
5290
5291身份管理操作结果回调函数,返回结果码和请求结果信息。
5292
5293**系统接口:** 此接口为系统接口。
5294
5295**系统能力:** SystemCapability.Account.OsAccount
5296
5297**参数:**
5298
5299| 参数名     | 类型                                    | 必填 | 说明                     |
5300| --------- | --------------------------------------- | ---- | ----------------------- |
5301| result    | number                                  | 是   | 表示身份认证结果代码。    |
5302| extraInfo | [RequestResult](#requestresult8)  | 是   | 针对不同情况传递具体信息。|
5303
5304**示例:**
5305  ```ts
5306  let idmCallback: osAccount.IIdmCallback = {
5307    onResult: (result: number, extraInfo: osAccount.RequestResult) => {
5308      console.info('callback result = ' + result)
5309      console.info('callback extraInfo = ' + JSON.stringify(extraInfo));
5310    }
5311  };
5312  ```
5313
5314### onAcquireInfo?<sup>8+</sup>
5315
5316onAcquireInfo?: (module: number, acquire: number, extraInfo: Uint8Array) => void;
5317
5318身份管理信息获取回调函数。
5319
5320**系统接口:** 此接口为系统接口。
5321
5322**系统能力:** SystemCapability.Account.OsAccount
5323
5324**参数:**
5325
5326| 参数名    | 类型     | 必填 | 说明                           |
5327| --------- | ------- | ---- | ----------------------------- |
5328| module    | number  | 是   | 指示用于身份验证的执行器类型。   |
5329| acquire   | number  | 是   | 指示不同身份验证执行器的tip代码。|
5330| extraInfo | Uint8Array | 是   | 保留参数。                     |
5331
5332**示例:**
5333  ```ts
5334  let idmCallback: osAccount.IIdmCallback = {
5335    onResult: (result: number, extraInfo: Object) => {
5336      console.info('callback result = ' + result)
5337      console.info('callback onResult = ' + JSON.stringify(extraInfo));
5338    },
5339    onAcquireInfo: (module: number, acquire: number, extraInfo: Uint8Array) => {
5340      console.info('callback module = ' + module);
5341      console.info('callback acquire = ' + acquire);
5342      console.info('callback onacquireinfo = ' + JSON.stringify(extraInfo));
5343    }
5344  };
5345  ```
5346
5347## GetPropertyRequest<sup>8+</sup>
5348
5349提供获取属性请求的信息。
5350
5351**系统接口:** 此接口为系统接口。
5352
5353**系统能力:** SystemCapability.Account.OsAccount
5354
5355| 名称    | 类型                                                         | 只读  | 可选 | 说明                   |
5356| -------- | ------------------------------------------------------------ | ----- | ----- | ----------------------- |
5357| authType | [AuthType](#authtype8)                            | 否 | 否  | 身份验证凭据类型。        |
5358| keys     | Array&lt;[GetPropertyType](#getpropertytype8)&gt; | 否 | 否  | 指示要获取的属性类型数组。 |
5359| accountId<sup>12+</sup> | number | 否 | 是  | 系统账号标识,默认为undefined。 |
5360
5361## SetPropertyRequest<sup>8+</sup>
5362
5363提供设置属性请求的信息。
5364
5365**系统接口:** 此接口为系统接口。
5366
5367**系统能力:** SystemCapability.Account.OsAccount
5368
5369| 名称    | 类型                                             | 只读  | 可选 | 说明                 |
5370| -------- | ------------------------------------------------ | ----- | ----- | -------------------- |
5371| authType | [AuthType](#authtype8)               | 否 | 否  | 身份验证凭据类型。     |
5372| key     | [SetPropertyType](#setpropertytype8) | 否 | 否  | 指示要设置的属性类型。 |
5373| setInfo  | Uint8Array                                       | 否 | 否  | 指示要设置的信息。     |
5374
5375## ExecutorProperty<sup>8+</sup>
5376
5377提供执行器的属性。
5378
5379**系统接口:** 此接口为系统接口。
5380
5381**系统能力:** SystemCapability.Account.OsAccount
5382
5383| 名称         | 类型                         |  只读 | 可选 | 说明              |
5384| ------------ | ---------------------------- | ----- | -----|----------------- |
5385| result       | number                       | 否    | 否   | 指示结果。         |
5386| authSubType  | [AuthSubType](#authsubtype8) | 否    | 否   | 指示认证凭据子类型。|
5387| remainTimes  | number                       | 否    | 是   | 指示剩余次数,默认为-1。     |
5388| freezingTime | number                       | 否    | 是   | 指示冻结时间,默认为-1。     |
5389| enrollmentProgress<sup>10+</sup> | string   | 否    | 是   | 指示录入进度,默认为空。 |
5390| sensorInfo<sup>10+</sup> | string           | 否    | 是   | 指示传感器信息,默认为空。 |
5391| nextPhaseFreezingTime<sup>12+</sup> | number | 否    | 是   | 指示下次冻结时间,默认为undefined。 |
5392| credentialLength<sup>20+</sup> | number | 否    | 是   | 指示凭据长度,默认为undefined。查询生物信息等无定长属性的凭据时返回undefined。 |
5393
5394## AuthResult<sup>8+</sup>
5395
5396表示认证结果的信息。
5397
5398**系统接口:** 此接口为系统接口。
5399
5400**系统能力:** SystemCapability.Account.OsAccount
5401
5402| 名称        | 类型        |  只读 | 可选 | 说明              |
5403| ------------ | ----------- | ----- | ----- | ----------------- |
5404| token        | Uint8Array  | 否    | 是   | 指示认证令牌,默认为空。      |
5405| remainTimes  | number      | 否    | 是   | 指示剩余次数,默认为空。      |
5406| freezingTime | number      | 否    | 是   | 指示冻结时间,默认为空。      |
5407| nextPhaseFreezingTime<sup>12+</sup> | number | 否    | 是   | 指示下次冻结时间,默认为undefined。 |
5408| credentialId<sup>12+</sup> | Uint8Array  | 否    | 是   | 指示凭据ID,默认为空。 |
5409| accountId<sup>12+</sup>         | number | 否    | 是   | 指示系统账号标识,默认为undefined。 |
5410| pinValidityPeriod<sup>12+</sup> | number | 否    | 是   | 指示认证有效期,默认为undefined。 |
5411
5412## CredentialInfo<sup>8+</sup>
5413
5414表示凭证信息。
5415
5416**系统接口:** 此接口为系统接口。
5417
5418**系统能力:** SystemCapability.Account.OsAccount
5419
5420| 名称        | 类型                                     |  只读 | 可选 | 说明              |
5421| ------------ | ---------------------------------------- | ----- | ----- | ----------------- |
5422| credType     | [AuthType](#authtype8)       | 否    | 否   | 指示凭据类型。     |
5423| credSubType  | [AuthSubType](#authsubtype8) | 否    | 否   | 指示凭据子类型。   |
5424| token        | Uint8Array                           | 否    | 否   | 指示认证令牌。     |
5425| accountId<sup>12+</sup>    | number | 否    | 是   | 系统账号标识,默认为undefined。 |
5426
5427## RequestResult<sup>8+</sup>
5428
5429表示请求结果的信息。
5430
5431**系统接口:** 此接口为系统接口。
5432
5433**系统能力:** SystemCapability.Account.OsAccount
5434
5435| 名称        | 类型        |  只读 | 可选 | 说明              |
5436| ------------ | ----------- | ----- | ----- | ----------------- |
5437| credentialId | Uint8Array  | 否    | 是   | 指示凭据索引,默认为空。      |
5438
5439## EnrolledCredInfo<sup>8+</sup>
5440
5441表示已注册凭据的信息。
5442
5443**系统接口:** 此接口为系统接口。
5444
5445**系统能力:** SystemCapability.Account.OsAccount
5446
5447| 名称        | 类型                                     |  只读 | 可选 | 说明              |
5448| ------------ | ---------------------------------------- | ----- | ----- | ------------------- |
5449| credentialId | Uint8Array                               | 否    | 否   | 指示凭据索引。       |
5450| authType     | [AuthType](#authtype8)       | 否    | 否   | 指示认证凭据类型。   |
5451| authSubType  | [AuthSubType](#authsubtype8) | 否    | 否   | 指示认证凭据子类型。 |
5452| templateId   | Uint8Array                               | 否    | 否   | 指示凭据模板ID。     |
5453| isAbandoned<sup>20+</sup>   | boolean                      | 否    | 是   | 指示凭据是否废弃。废弃后的凭据可能作为备份凭据保存一段时间。true表示已废弃,false表示未废弃。默认为undefined,表示是否废弃未定义。   |
5454| validityPeriod<sup>20+</sup>   | number                    | 否    | 是   | 指示凭据有效期。默认为undefined,表示有效期未定义。     |
5455
5456## GetPropertyType<sup>8+</sup>
5457
5458表示要获取的属性类型的枚举。
5459
5460**系统接口:** 此接口为系统接口。
5461
5462**系统能力:** SystemCapability.Account.OsAccount
5463
5464| 名称           | 值 | 说明      |
5465| ------------- | ------ | --------- |
5466| AUTH_SUB_TYPE | 1      | 认证子类型。 |
5467| REMAIN_TIMES  | 2      | 剩余次数。   |
5468| FREEZING_TIME | 3      | 冻结时间。   |
5469| ENROLLMENT_PROGRESS<sup>10+</sup> | 4      | 录入进度。   |
5470| SENSOR_INFO<sup>10+</sup> | 5      | 传感器信息。   |
5471| NEXT_PHASE_FREEZING_TIME<sup>12+</sup> | 6 | 下次冻结时间。 |
5472| CREDENTIAL_LENGTH<sup>20+</sup> | 7 | 凭据长度。 |
5473
5474## SetPropertyType<sup>8+</sup>
5475
5476表示要设置的属性类型的枚举。
5477
5478**系统接口:** 此接口为系统接口。
5479
5480**系统能力:** SystemCapability.Account.OsAccount
5481
5482| 名称           | 值 | 说明        |
5483| -------------- | ----- | ----------- |
5484| INIT_ALGORITHM | 1     | 初始化算法。 |
5485
5486## AuthType<sup>8+</sup>
5487
5488表示身份验证的凭据类型的枚举。
5489
5490**系统接口:** 此接口为系统接口。
5491
5492**系统能力:** SystemCapability.Account.OsAccount
5493
5494| 名称  | 值 | 说明             |
5495| ----- | ----- | ---------------- |
5496| PIN   | 1     | 表示PIN认证类型。 |
5497| FACE  | 2     | 表示脸部认证类型。|
5498| FINGERPRINT<sup>10+</sup>   | 4     | 表示指纹认证类型。 |
5499| RECOVERY_KEY<sup>12+</sup> | 8 | 表示键恢复类型。 |
5500| PRIVATE_PIN<sup>14+</sup> | 16 | 表示隐私PIN类型。 |
5501| DOMAIN<sup>9+</sup>  | 1024     | 表示域认证类型。|
5502
5503## AuthSubType<sup>8+</sup>
5504
5505表示用于认证的凭据子类型的枚举。
5506
5507**系统接口:** 此接口为系统接口。
5508
5509**系统能力:** SystemCapability.Account.OsAccount
5510
5511| 名称       | 值 | 说明               |
5512| ---------- | ----- | ------------------ |
5513| PIN_SIX    | 10000 | 表示6位凭证。       |
5514| PIN_NUMBER | 10001 | 表示自定义数字凭证。 |
5515| PIN_MIXED  | 10002 | 表示自定义混合凭据。 |
5516| PIN_FOUR<sup>12+</sup>   | 10003 | 表示4位凭证。 |
5517| PIN_PATTERN<sup>12+</sup>  | 10004 | 表示图案凭据。 |
5518| PIN_QUESTION<sup>14+</sup>  | 10005 | 表示密保问题凭据。 |
5519| FACE_2D    | 20000 | 表示2D 人脸凭证。   |
5520| FACE_3D    | 20001 | 表示3D 人脸凭证。   |
5521| FINGERPRINT_CAPACITIVE<sup>10+</sup>    | 30000 | 表示电容式指纹。   |
5522| FINGERPRINT_OPTICAL<sup>10+</sup>    | 30001 | 表示光学指纹。   |
5523| FINGERPRINT_ULTRASONIC<sup>10+</sup>    | 30002 | 表示超声波指纹。   |
5524| DOMAIN_MIXED<sup>9+</sup>    | 10240001 | 表示域认证混合凭证。   |
5525
5526## AuthTrustLevel<sup>8+</sup>
5527
5528表示认证结果的受信任级别的枚举。
5529
5530**系统接口:** 此接口为系统接口。
5531
5532**系统能力:** SystemCapability.Account.OsAccount
5533
5534| 名称  | 值 | 说明        |
5535| ---- | ------ | ----------- |
5536| ATL1 | 10000  | 信任级别 1。 |
5537| ATL2 | 20000  | 信任级别 2。 |
5538| ATL3 | 30000  | 信任级别 3。 |
5539| ATL4 | 40000  | 信任级别 4。 |
5540
5541## Module<sup>8+</sup>
5542
5543表示获取信息的模块的枚举。
5544
5545**系统接口:** 此接口为系统接口。
5546
5547**系统能力:** SystemCapability.Account.OsAccount
5548
5549| 名称       | 值 | 说明                     |
5550| --------- | ------ | ------------------------ |
5551| FACE_AUTH | 1      | 表示从人脸认证获取的信息。 |
5552
5553## ResultCode<sup>8+</sup>
5554
5555表示身份验证结果码。
5556
5557**系统接口:** 此接口为系统接口。
5558
5559**系统能力:** SystemCapability.Account.OsAccount
5560
5561| 名称                    | 值 | 说明                                     |
5562| ----------------------- | ----- | ---------------------------------------- |
5563| SUCCESS                 | 0     | 表示身份验证成功或支持此功能。             |
5564| FAIL                    | 1     | 表示验证器无法识别用户。                   |
5565| GENERAL_ERROR           | 2     | 表示其他错误。                            |
5566| CANCELED                | 3     | 表示身份验证已取消。                       |
5567| TIMEOUT                 | 4     | 表示身份验证已超时。                       |
5568| TYPE_NOT_SUPPORT        | 5     | 表示不支持此身份验证类型。                 |
5569| TRUST_LEVEL_NOT_SUPPORT | 6     | 表示不支持身份验证信任级别。               |
5570| BUSY                    | 7     | 表示身份验证任务正忙。等待几秒钟,然后重试。 |
5571| INVALID_PARAMETERS      | 8     | 表示参数不正确。                          |
5572| LOCKED                  | 9     | 指示身份验证器已锁定。                     |
5573| NOT_ENROLLED            | 10    | 表示用户尚未注册验证器。                   |
5574
5575## FaceTipsCode<sup>8+</sup>
5576
5577表示人脸验证过程中提示的枚举。
5578
5579**系统接口:** 此接口为系统接口。
5580
5581**系统能力:** SystemCapability.Account.OsAccount
5582
5583| 名称                          | 值 | 说明                                     |
5584| ----------------------------- | ----- | ---------------------------------------- |
5585| FACE_AUTH_TIP_TOO_BRIGHT      | 1     | 表示由于高照明,获得的面部图像太亮。         |
5586| FACE_AUTH_TIP_TOO_DARK        | 2     | 表示由于照明度低,获得的面部图像太暗。       |
5587| FACE_AUTH_TIP_TOO_CLOSE       | 3     | 表示面部离设备太近。                       |
5588| FACE_AUTH_TIP_TOO_FAR         | 4     | 表示面部离设备太远。                       |
5589| FACE_AUTH_TIP_TOO_HIGH        | 5     | 表示设备太高,仅捕捉面部上部。              |
5590| FACE_AUTH_TIP_TOO_LOW         | 6     | 表示设备太低,仅捕捉面部下部。              |
5591| FACE_AUTH_TIP_TOO_RIGHT       | 7     | 表示设备向右偏移,并且仅捕捉面部的右侧部分。 |
5592| FACE_AUTH_TIP_TOO_LEFT        | 8     | 表示设备向左偏移,并且仅捕捉面部的左侧部分。 |
5593| FACE_AUTH_TIP_TOO_MUCH_MOTION | 9     | 表示面部信息收集过程中面部移动过快。         |
5594| FACE_AUTH_TIP_POOR_GAZE       | 10    | 表示面部未朝向设备。                         |
5595| FACE_AUTH_TIP_NOT_DETECTED    | 11    | 表示未检测到人脸。                         |
5596
5597## FingerprintTips<sup>8+</sup>
5598
5599表示指纹身份验证过程中提示的枚举。
5600
5601**系统接口:** 此接口为系统接口。
5602
5603**系统能力:** SystemCapability.Account.OsAccount
5604
5605| 名称                          | 值 | 说明                                            |
5606| ----------------------------- | ----- | ----------------------------------------------- |
5607| FINGERPRINT_TIP_GOOD          | 0     | 表示采集的图像良好。                              |
5608| FINGERPRINT_TIP_IMAGER_DIRTY  | 1     | 表示由于传感器上可疑或检测到污垢,指纹图像噪声过大。 |
5609| FINGERPRINT_TIP_INSUFFICIENT  | 2     | 表示由于检测到的情况,指纹图像噪声太大,无法处理。   |
5610| FINGERPRINT_TIP_PARTIAL       | 3     | 表示仅检测到部分指纹图像。                         |
5611| FINGERPRINT_TIP_TOO_FAST      | 4     | 表示指纹图像由于快速运动而不完整。                  |
5612| FINGERPRINT_TIP_TOO_SLOW      | 5     | 表示由于缺少运动,指纹图像无法读取。                |
5613| FINGERPRINT_TIP_FINGER_DOWN<sup>10+</sup>   | 6     | 表示手指落下。                  |
5614| FINGERPRINT_TIP_FINGER_UP<sup>10+</sup>     | 7     | 表示手指抬起。                |
5615
5616## OsAccountInfo
5617
5618表示系统账号信息。
5619
5620**系统能力:** SystemCapability.Account.OsAccount
5621
5622| 名称      | 类型   | 只读  | 可选  | 说明       |
5623| ----------- | ------ | ---- | ---- | ---------- |
5624| shortName<sup>12+</sup> | string | 否 | 是  | 系统账号的短名称。<br>**系统接口:** 此接口为系统接口,默认为空。 |
5625| isLoggedIn<sup>12+</sup> | boolean | 否 | 是  | 是否登录。true表示已登录;false表示未登录。<br>**系统接口:** 此接口为系统接口,默认为false。 |
5626
5627## OsAccountType
5628
5629表示系统账号类型的枚举。
5630
5631**系统能力:** SystemCapability.Account.OsAccount5632
5633| 名称   | 值 | 说明         |
5634| ------ | ------ | ----------- |
5635| PRIVATE<sup>12+</sup> | 1024  | 隐私账号。隐私账号只能有一个。<br>**系统接口:** 此接口为系统接口。   |
5636
5637## DomainAccountInfo<sup>8+</sup>
5638
5639表示域账号信息。
5640
5641**系统能力:** SystemCapability.Account.OsAccount
5642
5643| 名称      | 类型   | 只读  | 可选  | 说明       |
5644| ----------- | ------ | ---- | ---- | ---------- |
5645| accountId<sup>10+</sup> | string | 否 | 是  | 域账号标识。<br>**系统接口:** 此接口为系统接口,默认为undefined。 |
5646| isAuthenticated<sup>11+</sup>| boolean | 否 | 是  | 指示域账号是否已认证。true表示指定的域账号已认证;false表示指定的域账号未认证。<br>**系统接口:** 此接口为系统接口,默认为false。|
5647
5648## ConstraintSourceTypeInfo<sup>9+</sup>
5649
5650表示约束来源类型信息。
5651
5652**系统接口:** 此接口为系统接口。
5653
5654**系统能力:** SystemCapability.Account.OsAccount
5655
5656| 名称      | 类型   | 只读  | 可选  | 说明       |
5657| ----------- | ------ | ---- | ---- | ---------- |
5658| localId      | number | 否 | 否  | 系统账号ID     |
5659| type | [ConstraintSourceType](#constraintsourcetype9) | 否 | 否  | 约束来源类型。 |
5660
5661## ConstraintSourceType<sup>9+</sup>
5662
5663表示约束来源类型的枚举。
5664
5665**系统接口:** 此接口为系统接口。
5666
5667**系统能力:** SystemCapability.Account.OsAccount
5668
5669| 名称   | 值 | 说明         |
5670| ------ | ------ | ------------ |
5671| CONSTRAINT_NOT_EXIST  | 0      | 约束不存在。 |
5672| CONSTRAINT_TYPE_BASE | 1      | 约束源自系统设置。   |
5673| CONSTRAINT_TYPE_DEVICE_OWNER  | 2   | 约束源自设备所有者设置。   |
5674| CONSTRAINT_TYPE_PROFILE_OWNER  | 3  | 约束源自资料所有者设置。   |
5675
5676## AuthStatusInfo<sup>10+</sup>
5677
5678表示认证状态信息。
5679
5680**系统接口:** 此接口为系统接口。
5681
5682**系统能力:** SystemCapability.Account.OsAccount
5683
5684| 名称      | 类型   | 只读  | 可选 | 说明       |
5685| ----------- | ------ | ---- | ---- | ---------- |
5686| remainTimes  | number | 否 | 否  | 剩余次数。   |
5687| freezingTime | number | 否 | 否  | 冻结时间。 |
5688
5689## GetDomainAccessTokenOptions<sup>10+</sup>
5690
5691表示获取域访问令牌的选项。
5692
5693**系统接口:** 此接口为系统接口。
5694
5695**系统能力:** SystemCapability.Account.OsAccount
5696
5697| 名称      | 类型   | 只读  | 可选 | 说明       |
5698| ----------- | ------ | ---- | ---- | ---------- |
5699| domainAccountInfo  | [DomainAccountInfo](#domainaccountinfo8) | 否 | 否  | 域账号的信息。   |
5700| domainAccountToken | Uint8Array | 否 | 否  | 域账号的令牌。 |
5701| businessParams | Record<string, Object> | 否 | 否  | 业务参数,由业务方根据请求协议自定义。 |
5702| callerUid | number | 否 | 否  | 调用方唯一标识符。 |
5703
5704## GetDomainAccountInfoOptions<sup>10+</sup>
5705
5706表示查询域账号信息的选项。
5707
5708**系统接口:** 此接口为系统接口。
5709
5710**系统能力:** SystemCapability.Account.OsAccount
5711
5712| 名称      | 类型   | 只读  | 可选 | 说明       |
5713| ----------- | ------ | ---- | ---- | ---------- |
5714| accountName | string | 否 | 否  | 域账号名。 |
5715| domain      | string | 否 | 是  | 域名。默认为undefined。|
5716| serverConfigId<sup>12+</sup>| string | 否 | 是  | 域账号所属服务器标识。默认为undefined。|
5717
5718## GetDomainAccountInfoPluginOptions<sup>10+</sup>
5719
5720表示插件查询域账号信息的选项。GetDomainAccountInfoPluginOptions类继承[GetDomainAccountInfoOptions](#getdomainaccountinfooptions10)
5721
5722**系统接口:** 此接口为系统接口。
5723
5724**系统能力:** SystemCapability.Account.OsAccount
5725
5726| 名称      | 类型   | 只读  | 可选 | 说明       |
5727| ----------- | ------ | ---- | ---- | ---------- |
5728| callerUid | number | 否 | 否  | 调用方唯一标识符。 |
5729
5730## OsAccountSwitchEventData<sup>12+</sup>
5731
5732表示系统账号前后台开始切换和结束切换事件的数据结构。
5733
5734**系统接口:** 此接口为系统接口。
5735
5736**系统能力:** SystemCapability.Account.OsAccount
5737
5738| 名称      | 类型   | 必填 | 说明       |
5739| ----------- | ------ | ---- | ---------- |
5740| fromAccountId | number | 是   | 切换前系统账号ID。 |
5741| toAccountId | number | 是   | 切换后系统账号ID。 |
5742
5743## CreateOsAccountOptions<sup>12+</sup>
5744
5745表示用于创建系统账号的可选参数。
5746
5747**系统接口:** 此接口为系统接口。
5748
5749**系统能力:** SystemCapability.Account.OsAccount
5750
5751| 名称      | 类型   | 只读  | 可选   | 说明       |
5752| ----------- | ------ | ---- | ---- | ---------- |
5753| shortName | string | 否 | 否   | 表示账号短名称(用作个人文件夹目录)。 <br/>**约束:** <br>1. 不允许出现的字符:\< \> \| : " * ? / \\<br>2. 不允许独立出现的字符串:.或..<br>3. 长度不超过255个字符。|
5754| disallowedPreinstalledBundles<sup>19+</sup> | Array&lt;string&gt; | 否 | 是   | 表示预置应用禁止名单,名单中的应用不可被安装在设备上,默认为空列表。|
5755| allowedPreinstalledBundles<sup>19+</sup> | Array&lt;string&gt; | 否 | 是   | 表示预置应用允许名单,仅名单中的应用可以被安装在设备上,默认为std::nullopt。|
5756
5757## CreateOsAccountForDomainOptions<sup>12+</sup>
5758
5759表示用于创建与指定域账号绑定的系统账号的可选参数。继承自[CreateOsAccountOptions](#createosaccountoptions12)。
5760
5761**系统接口:** 此接口为系统接口。
5762
5763**系统能力:** SystemCapability.Account.OsAccount
5764
5765| 名称      | 类型   | 只读  | 可选   | 说明       |
5766| ----------- | ------ | ---- | ---- | ---------- |
5767| shortName | string | 否 | 否   | 表示账号短名称(用作个人文件夹目录)。 <br/>**约束:** <br>1. 不允许出现的字符:\< \> \| : " * ? / \\<br>2. 不允许独立出现的字符串:.或..<br>3. 长度不超过255个字符。|
5768
5769## GetAuthInfoOptions<sup>12+</sup>
5770
5771表示[查询认证凭据信息](#getauthinfo12)的可选参数集合。
5772
5773**系统接口:** 此接口为系统接口。
5774
5775**系统能力:** SystemCapability.Account.OsAccount
5776
5777| 名称      | 类型                    | 只读  | 可选   | 说明       |
5778| --------- | ---------------------- | ---- | ---- | ---------- |
5779| authType  | [AuthType](#authtype8) | 否 | 是   | 认证类型,默认为undefined。 |
5780| accountId | number                 | 否 | 是   | 系统账号标识,默认为undefined。 |
5781
5782## AuthIntent<sup>12+</sup>
5783
5784表示认证意图的枚举。
5785
5786**系统接口:** 此接口为系统接口。
5787
5788**系统能力:** SystemCapability.Account.OsAccount
5789
5790| 名称     | 值   | 说明       |
5791| -------- | --- | ---------- |
5792| UNLOCK   | 1   | 解锁意图。 |
5793| SILENT_AUTH<sup>14+</sup>  | 2   | 静默认证意图。 |
5794| QUESTION_AUTH<sup>14+</sup>   | 3   | 密保问题认证意图。 |
5795| ABANDONED_PIN_AUTH<sup>20+</sup>   | 4   | 废弃PIN码认证意图。用户修改锁屏密码后,旧的PIN码被废弃。废弃PIN存在期间,用户如果忘记密码可以通过废弃PIN认证通过后重置锁屏密码。 |
5796
5797## RemoteAuthOptions<sup>12+</sup>
5798
5799表示远程认证的可选参数集合。
5800
5801**系统接口:** 此接口为系统接口。
5802
5803**系统能力:** SystemCapability.Account.OsAccount
5804
5805| 名称               | 类型    | 只读  | 可选 | 说明       |
5806| ------------------ | ------ | ---- | ---- | ---------- |
5807| verifierNetworkId  | string | 否 | 是  | 凭据验证者的网络标识,默认为空。 |
5808| collectorNetworkId | string | 否 | 是  | 凭据收集者的网络标识,默认为空。 |
5809| collectorTokenId   | number | 否 | 是  | 凭据收集者的令牌标识,默认为undefined。 |
5810
5811## AuthOptions<sup>12+</sup>
5812
5813表示[认证用户](#auth12)的可选参数集合。
5814
5815**系统接口:** 此接口为系统接口。
5816
5817**系统能力:** SystemCapability.Account.OsAccount
5818
5819| 名称               | 类型    | 只读  | 可选 | 说明       |
5820| ------------------ | ------ | ---- | ---- | ---------- |
5821| accountId          | number | 否 | 是  | 系统账号标识,默认为undefined。 |
5822| authIntent         | [AuthIntent](#authintent12) | 否 | 是  | 认证意图,默认为undefined。 |
5823| remoteAuthOptions  | [RemoteAuthOptions](#remoteauthoptions12) | 否 | 是  | 远程认证选项,默认为undefined。 |
5824
5825## GetInputDataOptions<sup>12+</sup>
5826
5827表示[通知调用者获取数据](#ongetdata8)的可选参数集合。
5828
5829**系统接口:** 此接口为系统接口。
5830
5831**系统能力:** SystemCapability.Account.OsAccount
5832
5833| 名称               | 类型    | 只读  | 可选 | 说明       |
5834| ------------------ | ------ | ---- | ---- | ---------- |
5835| challenge          | Uint8Array | 否 | 是  | 挑战值,默认为undefined。 |
5836