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