1# nfctech (标准NFC-Tag Nfc 技术) 2 3本模块主要用于采用不同Nfc技术的Tag的读写操作。 4 5> **说明:** 6> 7> 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 8 9## 导入模块 10 11```js 12import tag from '@ohos.nfc.tag'; 13``` 14 15## NfcATag 16 17NfcATag 提供 NFC-A(ISO 14443-3A)技术的属性和I/O操作的访问,继承自[TagSession](js-apis-tagSession.md)。 18 19TagSession是所有NFC Tag技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 20 21以下是NfcATag的独有接口。 22 23### NfcATag.getSak 24 25getSak(): number 26 27获取NFC-A标签的SAK值。 28 29**系统能力:** SystemCapability.Communication.NFC.Tag 30 31**返回值:** 32 33| **类型** | **说明** | 34| ------------------ | --------------------------| 35| number | NfcA 标签的SAK值,十六进制表示,范围是0x00~0xFF。 | 36 37**示例:** 38 39```js 40import tag from '@ohos.nfc.tag'; 41 42// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcA' correctly. 43let sak : number = nfcA.getSak(); 44console.log("nfcA sak: " + sak); 45``` 46 47### NfcATag.getAtqa 48 49getAtqa(): number[] 50 51获取NFC-A标签的Atqa值。 52 53**系统能力:** SystemCapability.Communication.NFC.Tag 54 55**返回值:** 56 57| **类型** | **说明** | 58| ------------------ | --------------------------| 59| number[] | NfcA 标签的Atqa值,每个number十六进制表示,范围是0x00~0xFF。 | 60 61**示例:** 62 63```js 64import tag from '@ohos.nfc.tag'; 65 66// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcA' correctly. 67let atqa : number[] = nfcA.getAtqa(); 68console.log("nfcA atqa: " + atqa); 69``` 70 71## NfcBTag 72 73NfcBTag 提供对NFC-B(ISO 14443-3B)技术的属性和I/O操作的访问,继承自TagSession。 74 75TagSession是所有NFC Tag技术类型的基类,提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 76 77以下是NfcBTag的独有接口。 78 79### NfcBTag.getRespAppData 80 81getRespAppData(): number[] 82 83获取标签的应用程序数据。 84 85**系统能力:** SystemCapability.Communication.NFC.Tag 86 87**返回值:** 88 89| **类型** | **说明** | 90| ------------------ | --------------------------| 91| number[] | NfcB 标签的应用程序数据,每个number十六进制表示,范围是0x00~0xFF。 | 92 93**示例:** 94 95```js 96import tag from '@ohos.nfc.tag'; 97 98// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcB' correctly. 99let respAppData : number[] = nfcB.getRespAppData(); 100console.log("nfcB respAppData: " + respAppData); 101``` 102 103### NfcBTag.getRespProtocol 104 105getRespProtocol(): number[] 106 107获取标签的协议信息。 108 109**系统能力:** SystemCapability.Communication.NFC.Tag 110 111**返回值:** 112 113| **类型** | **说明** | 114| ------------------ | --------------------------| 115| number[] | NfcB 标签的协议信息,每个number十六进制表示,范围是0x00~0xFF。| 116 117**示例:** 118 119```js 120import tag from '@ohos.nfc.tag'; 121 122// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcB' correctly. 123let respProtocol : number[] = nfcB.getRespProtocol(); 124console.log("nfcB respProtocol: " + respProtocol); 125``` 126 127## NfcFTag 128 129NfcFTag 提供对NFC-F(JIS 6319-4)技术的属性和I/O操作的访问,继承自TagSession。 130 131TagSession是所有NFC Tag技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 132 133以下是NfcFTag的独有接口。 134 135### NfcFTag.getSystemCode 136 137getSystemCode(): number[] 138 139从标签实例获取系统代码。 140 141**系统能力:** SystemCapability.Communication.NFC.Tag 142 143**返回值:** 144 145| **类型** | **说明** | 146| ------------------ | --------------------------| 147| number[] | NfcF 标签的系统代码,每个number十六进制表示,范围是0x00~0xFF。| 148 149**示例:** 150 151```js 152import tag from '@ohos.nfc.tag'; 153 154// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcF' correctly. 155let systemCode : number[] = nfcF.getSystemCode(); 156console.log("nfcF systemCode: " + systemCode); 157``` 158 159### NfcFTag.getPmm 160 161getPmm(): number[] 162 163从标签实例获取PMm(由IC代码和制造商参数组成)。 164 165**系统能力:** SystemCapability.Communication.NFC.Tag 166 167**返回值:** 168 169| **类型** | **说明** | 170| ------------------ | --------------------------| 171| number[] | NfcF 标签的PMm信息,每个number十六进制表示,范围是0x00~0xFF。| 172 173**示例:** 174 175```js 176import tag from '@ohos.nfc.tag'; 177 178// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcF' correctly. 179let pmm : number[] = nfcF.getPmm(); 180console.log("nfcF pmm: " + pmm); 181``` 182 183## NfcVTag 184 185NfcVTag 提供对NFC-V(ISO 15693)技术的属性和I/O操作的访问,继承自TagSession。 186 187TagSession是所有NFC Tag技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 188 189以下是NfcVTag的独有接口。 190 191### NfcvTag.getResponseFlags 192 193getResponseFlags(): number 194 195从标签实例实例获取响应标志。 196 197**系统能力:** SystemCapability.Communication.NFC.Tag 198 199**返回值:** 200 201| **类型** | **说明** | 202| ------------------ | --------------------------| 203| number | NfcV 标签的响应标志,十六进制表示,范围是0x00~0xFF。| 204 205**示例:** 206 207```js 208import tag from '@ohos.nfc.tag'; 209 210// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcV' correctly. 211let responseFlags : number = nfcV.getResponseFlags(); 212console.log("nfcV responseFlags: " + responseFlags); 213``` 214 215### NfcvTag.getDsfId 216 217getDsfId(): number 218 219从标签实例实例获取数据存储格式标识符(DSFID)。 220 221**系统能力:** SystemCapability.Communication.NFC.Tag 222 223**返回值:** 224 225| **类型** | **说明** | 226| ------------------ | --------------------------| 227| number | NfcV 标签的数据存储格式标识符,十六进制表示,范围是0x00~0xFF。| 228 229**示例:** 230 231```js 232import tag from '@ohos.nfc.tag'; 233 234// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'nfcV' correctly. 235let dsfId : number = nfcV.getDsfId(); 236console.log("nfcV dsfId: " + dsfId); 237``` 238 239## IsoDepTag<sup>9+</sup> 240 241IsoDepTag 提供对ISO-DEP(ISO 14443-4)技术的属性和I/O操作的访问,继承自TagSession。 242 243TagSession是所有NFC Tag技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 244 245以下是IsoDepTag的独有接口。 246 247### IsoDepTag.getHistoricalBytes<sup>9+</sup> 248 249getHistoricalBytes(): number[] 250 251获取标签的历史字节,针对基于NfcA通信技术的IsoDep卡片。 252 253**系统能力:** SystemCapability.Communication.NFC.Tag 254 255**返回值:** 256 257| **类型** | **说明** | 258| ------------------ | --------------------------| 259| number[] | IsoDepTag 标签的历史字节,每个number十六进制表示,范围是0x00~0xFF。如果该IsoDep类型Tag是基于NfcB技术的,则该返回值为空。| 260 261**示例:** 262 263```js 264import tag from '@ohos.nfc.tag'; 265 266// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'isoDep' correctly. 267let historicalBytes : number[] = isoDep.getHistoricalBytes(); 268console.log("isoDep historicalBytes: " + historicalBytes); 269``` 270 271### IsoDepTag.getHiLayerResponse<sup>9+</sup> 272 273getHiLayerResponse(): number[] 274 275获取标签的更高层响应字节,针对基于NfcB通信技术的IsoDep卡片。 276 277**系统能力:** SystemCapability.Communication.NFC.Tag 278 279**返回值:** 280 281| **类型** | **说明** | 282| ------------------ | --------------------------| 283| number[] | IsoDepTag 标签的更高层响应字节,每个number十六进制表示,范围是0x00~0xFF。如果该IsoDep类型Tag是基于NfcA技术的,则该返回值为空。| 284 285**示例:** 286 287```js 288import tag from '@ohos.nfc.tag'; 289 290// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'isoDep' correctly. 291let hiLayerResponse : number[] = isoDep.getHiLayerResponse(); 292console.log("isoDep hiLayerResponse: " + hiLayerResponse); 293``` 294 295### IsoDepTag.isExtendedApduSupported<sup>9+</sup> 296 297isExtendedApduSupported(): Promise<boolean> 298 299检查是否支持扩展的APDU,使用Promise方式作为异步方法。 300 301**需要权限:** ohos.permission.NFC_TAG 302 303**系统能力:** SystemCapability.Communication.NFC.Tag 304 305**返回值:** 306 307| **类型** | **说明** | 308| ------------------ | --------------------------| 309| Promise<boolean> | 以Promise形式返回检查结果,true: 支持, false: 不支持。| 310 311**错误码:** 312 313以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 314 315| 错误码ID | 错误信息| 316| ------- | -------| 317| 3100201 | Tag running state is abnormal in service. | 318 319**示例:** 320 321```js 322import tag from '@ohos.nfc.tag'; 323import {BusinessError} from '@ohos.base'; 324 325// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'isoDep' correctly. 326 327// connect the tag at first if not connected. 328if (!isoDep.isTagConnected()) { 329 if (!isoDep.connectTag()) { 330 console.log("isoDep connectTag failed."); 331 return; 332 } 333} 334 335try { 336 isoDep.isExtendedApduSupported().then((response: boolean) => { 337 console.log("isoDep isExtendedApduSupported Promise response: " + response); 338 }).catch((err: BusinessError) => { 339 console.error("isoDep isExtendedApduSupported Promise Code: ${err.code}, message: ${err.message}"); 340 }); 341} catch (busiError) { 342 console.error("isoDep isExtendedApduSupported Promise Code: ${(busiError as Businsess).code}, " + 343 "message: ${(busiError as Businsess).message}"); 344} 345``` 346 347### IsoDepTag.isExtendedApduSupported<sup>9+</sup> 348 349isExtendedApduSupported(callback: AsyncCallback\<boolean>): void 350 351检查是否支持扩展的APDU,使用AsyncCallback方式作为异步方法。 352 353**需要权限:** ohos.permission.NFC_TAG 354 355**系统能力:** SystemCapability.Communication.NFC.Tag 356 357**参数:** 358 359| 参数名 | 类型 | 必填 | 说明 | 360| -------- | ----------------------- | ---- | -------------------------------------- | 361| callback | AsyncCallback\<boolean> | 是 | 回调函数,true: 支持, false: 不支持。 | 362 363**错误码:** 364 365以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 366 367| 错误码ID | 错误信息| 368| ------- | -------| 369| 3100201 | Tag running state is abnormal in service. | 370 371**示例:** 372 373```js 374import tag from '@ohos.nfc.tag'; 375import {BusinessError} from '@ohos.base'; 376 377// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'isoDep' correctly. 378 379// connect the tag at first if not connected. 380if (!isoDep.isTagConnected()) { 381 if (!isoDep.connectTag()) { 382 console.log("isoDep connectTag failed."); 383 return; 384 } 385} 386 387try { 388 isoDep.isExtendedApduSupported((err: BusinessError, response: boolean) => { 389 if (err) { 390 console.log("isoDep isExtendedApduSupported AsyncCallback Code: ${err.code}, message: ${err.message}"); 391 } else { 392 console.log("isoDep isExtendedApduSupported AsyncCallback response: " + response); 393 } 394 }); 395} catch (busiErr) { 396 console.error("isoDep isExtendedApduSupported AsyncCallback Code: ${(busiError as Business).code}, " + 397 "message: ${(busiError as Business).message}"); 398} 399``` 400 401## NdefMessage<sup>9+</sup> 402 403### NdefMessage.getNdefRecords<sup>9+</sup> 404 405getNdefRecords(): [tag.NdefRecord](js-apis-nfcTag.md#ndefrecord9)[] 406 407获取NDEF消息中的所有记录。 408 409**系统能力:** SystemCapability.Communication.NFC.Tag 410 411**返回值:** 412 413| **类型** | **说明** | 414| ------------------ | --------------------------| 415| [tag.NdefRecord](js-apis-nfcTag.md#ndefrecord9)[] | NDEF标签的Record列表,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。 | 416 417**示例:** 418 419```js 420import tag from '@ohos.nfc.tag'; 421 422// Obtains ndefMessage from tag.ndef.createNdefMessage or ndefTag.getNdefMessage. 423// let ndefMessage : tag.NdefMessage = tag.ndef.createNdefMessage(...); 424// let ndefMessage : tag.NdefMessage = ndefTag.getNdefMessage(); 425 426let ndefRecords : tag.NdefRecord[] = ndefMessage.getNdefRecords(); 427console.log("ndef ndefRecords number: " + ndefRecords.length); 428``` 429 430## NdefTag<sup>9+</sup> 431 432提供对已格式化为NDEF的NFC标签的数据和操作的访问,继承自TagSession。 433 434TagSession是所有NFC Tag技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 435 436以下是NdefTag的独有接口。 437 438### NdefTag.getNdefTagType<sup>9+</sup> 439 440getNdefTagType(): [tag.NfcForumType](js-apis-nfcTag.md#nfcforumtype9) 441 442获取NDEF标签的类型。 443 444**系统能力:** SystemCapability.Communication.NFC.Tag 445 446**返回值:** 447 448| **类型** | **说明** | 449| ------------------ | --------------------------| 450| [tag.NfcForumType](js-apis-nfcTag.md#nfcforumtype9) | NDEF标签类型,包括NFC FORUM TYPE 1/2/3/4等。| 451 452**示例:** 453 454```js 455import tag from '@ohos.nfc.tag'; 456 457// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 458let ndefTagType : tag.NfcForumType = ndefTag.getNdefTagType(); 459console.log("ndef ndefTagType: " + ndefTagType); 460``` 461 462### NdefTag.getNdefMessage<sup>9+</sup> 463 464getNdefMessage(): [NdefMessage](#ndefmessage9) 465 466获取发现NDEF标签时,从标签读取的Message。 467 468**系统能力:** SystemCapability.Communication.NFC.Tag 469 470**返回值:** 471 472| **类型** | **说明** | 473| ------------------ | --------------------------| 474| [NdefMessage](#ndefmessage9) | NDEF标签的Message,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。| 475 476**示例:** 477```js 478import tag from '@ohos.nfc.tag'; 479 480// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 481let ndefMessage : tag.NdefMessage = ndefTag.getNdefMessage(); 482console.log("ndef ndefMessage: " + ndefMessage); 483``` 484 485### NdefTag.isNdefWritable<sup>9+</sup> 486 487isNdefWritable(): boolean 488 489检查NDEF标签是否可写。在调用写数据接口前,需要先判断是否支持写操作。 490 491**系统能力:** SystemCapability.Communication.NFC.Tag 492 493**返回值:** 494 495| **类型** | **说明** | 496| ------------------ | --------------------------| 497| boolean | 检查结果,true: 可写, false: 不可写。| 498 499**示例:** 500 501```js 502import tag from '@ohos.nfc.tag'; 503 504// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 505let isWritable : boolean = ndefTag.isNdefWritable(); 506console.log("ndef isNdefWritable: " + isWritable); 507``` 508 509### NdefTag.readNdef<sup>9+</sup> 510 511readNdef(): Promise\<[NdefMessage](#ndefmessage9)> 512 513读取标签上的NDEF消息,使用Promise方式作为异步方法。 514 515**需要权限:** ohos.permission.NFC_TAG 516 517**系统能力:** SystemCapability.Communication.NFC.Tag 518 519**返回值:** 520 521| **类型** | **说明** | 522| ------------------ | --------------------------| 523| Promise\<[NdefMessage](#ndefmessage9)> | 以Promise形式返回从NDEF标签中读取到的Message数据对象。| 524 525**错误码:** 526 527以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 528 529| 错误码ID | 错误信息| 530| ------- | -------| 531| 3100201 | Tag running state is abnormal in service. | 532 533**示例:** 534 535```js 536import tag from '@ohos.nfc.tag'; 537import {BusinessError} from '@ohos.base'; 538 539// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 540 541// connect the tag at first if not connected. 542if (!ndefTag.isTagConnected()) { 543 if (!ndefTag.connectTag()) { 544 console.log("ndefTag connectTag failed."); 545 return; 546 } 547} 548 549try { 550 ndefTag.readNdef().then((ndefmessage : tag.NdefMessage) => { 551 console.log("ndef readNdef Promise ndefmessage: " + ndefmessage); 552 }).catch((err : BusinessError)=> { 553 console.error("ndef readNdef Promise err Code: ${err.code}, message: ${err.message}"); 554 }); 555} catch (busiError) { 556 console.error("ndef readNdef Promise catched busiError Code: ${(busiError as BusinessError).code}, " + 557 "message: ${(busiError as BusinessError).message}"); 558} 559``` 560 561### NdefTag.readNdef<sup>9+</sup> 562 563readNdef(callback: AsyncCallback\<[NdefMessage](#ndefmessage9)>): void 564 565读取标签上的NDEF消息,使用AsyncCallback方式作为异步方法。 566 567**需要权限:** ohos.permission.NFC_TAG 568 569**系统能力:** SystemCapability.Communication.NFC.Tag 570 571**参数:** 572 573| 参数名 | 类型 | 必填 | 说明 | 574| -------- | ----------------------- | ---- | -------------------------------------- | 575| callback | AsyncCallback\<[NdefMessage](#ndefmessage9)> | 是 | 回调函数,返回从NDEF标签中读取到的Message信息。| 576 577**错误码:** 578 579以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 580 581| 错误码ID | 错误信息| 582| ------- | -------| 583| 3100201 | Tag running state is abnormal in service. | 584 585**示例:** 586 587```js 588import tag from '@ohos.nfc.tag'; 589import {BusinessError} from '@ohos.base'; 590 591// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 592 593// connect the tag at first if not connected. 594if (!ndefTag.isTagConnected()) { 595 if (!ndefTag.connectTag()) { 596 console.log("ndefTag connectTag failed."); 597 return; 598 } 599} 600 601try { 602 ndefTag.readNdef((err : BusinessError, ndefmessage : tag.NdefMessage)=> { 603 if (err) { 604 console.log("ndef readNdef AsyncCallback err Code: ${err.code}, message: ${err.message}"); 605 } else { 606 console.log("ndef readNdef AsyncCallback ndefmessage: " + ndefmessage); 607 } 608 }); 609} catch (busiError) { 610 console.log("ndef readNdef AsyncCallback catched Code: ${(busiError : BusinessError).code}," + 611 " message: ${(busiError : BusinessError).message}"); 612} 613``` 614 615### NdefTag.writeNdef<sup>9+</sup> 616 617writeNdef(msg: [NdefMessage](#ndefmessage9)): Promise\<void> 618 619将NDEF Messsage数据对象写入标签,使用Promise方式作为异步方法。 620 621**需要权限:** ohos.permission.NFC_TAG 622 623**系统能力:** SystemCapability.Communication.NFC.Tag 624 625**参数:** 626 627| 参数名 | 类型 | 必填 | 说明 | 628| -------- | ----------------------- | ---- | -------------------------------------- | 629| msg | [NdefMessage](#ndefmessage9) | 是 | NDEF Message数据对象。| 630 631**错误码:** 632 633以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 634 635| 错误码ID | 错误信息| 636| ------- | -------| 637| 3100201 | Tag running state is abnormal in service. | 638 639**示例:** 640 641```js 642import tag from '@ohos.nfc.tag'; 643import {BusinessError} from '@ohos.base'; 644 645// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 646// ndefMessage created from raw data, such as: 647let ndefMessage : tag.NdefMessage = 648 tag.ndef.createNdefMessage([0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]); // MUST can be parsed as NDEF Record. 649// or ndefMessage created from tag.ndef.createNdefMessage(ndefRecords: NdefRecord[]) 650 651// connect the tag at first if not connected. 652if (!ndefTag.isTagConnected()) { 653 if (!ndefTag.connectTag()) { 654 console.log("ndefTag connectTag failed."); 655 return; 656 } 657} 658 659try { 660 ndefTag.writeNdef(ndefMessage).then(() => { 661 console.log("ndef writeNdef Promise success."); 662 }).catch((err : BusinessError)=> { 663 console.error("ndef writeNdef err Code: ${err.code}, message: ${err.message}"); 664 }); 665} catch (busiError) { 666 console.error("ndef writeNdef Promise catch busiError Code: ${(busiError as Businsess).code}, " + 667 "message: ${(busiError as Businsess).message}"); 668} 669``` 670 671### NdefTag.writeNdef<sup>9+</sup> 672 673writeNdef(msg: [NdefMessage](#ndefmessage9), callback: AsyncCallback\<void>): void 674 675将NDEF Message数据对象写入此标签,使用AsyncCallback方式作为异步方法。 676 677**需要权限:** ohos.permission.NFC_TAG 678 679**系统能力:** SystemCapability.Communication.NFC.Tag 680 681**参数:** 682 683| 参数名 | 类型 | 必填 | 说明 | 684| -------- | ----------------------- | ---- | -------------------------------------- | 685| msg | [NdefMessage](#ndefmessage9) | 是 | NDEF Message数据对象。 | 686| callback | AsyncCallback\<void> | 是 | 回调函数。 | 687 688**错误码:** 689 690以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 691 692| 错误码ID | 错误信息| 693| ------- | -------| 694| 3100201 | Tag running state is abnormal in service. | 695 696**示例:** 697 698```js 699import tag from '@ohos.nfc.tag'; 700import {BusinessError} from '@ohos.base'; 701 702// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 703// ndefMessage created from raw data, such as: 704let ndefMessage : tag.NdefMessage = 705 tag.ndef.createNdefMessage([0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]); // MUST can be parsed as NDEF Record. 706// or ndefMessage created from tag.ndef.createNdefMessage(ndefRecords: NdefRecord[]) 707 708// connect the tag at first if not connected. 709if (!ndefTag.isTagConnected()) { 710 if (!ndefTag.connectTag()) { 711 console.log("ndefTag connectTag failed."); 712 return; 713 } 714} 715 716try { 717 ndefTag.writeNdef(ndefMessage, (err : BusinessError)=> { 718 if (err) { 719 console.error("ndef writeNdef AsyncCallback Code: ${err.code}, message: ${err.message}"); 720 } else { 721 console.log("ndef writeNdef AsyncCallback success."); 722 } 723 }); 724} catch (busiError) { 725 console.error("ndef writeNdef AsyncCallback catch busiError Code: ${(busiError as Businsess).code}," + 726 " message: ${(busiError as Businsess).message}"); 727} 728``` 729 730### NdefTag.canSetReadOnly<sup>9+</sup> 731 732canSetReadOnly(): boolean 733 734检查NDEF标签是否可以设置为只读。 735 736**需要权限:** ohos.permission.NFC_TAG 737 738**系统能力:** SystemCapability.Communication.NFC.Tag 739 740**返回值:** 741 742| **类型** | **说明** | 743| ------------------ | --------------------------| 744| boolean| true: NDEF标签可设置为只读, false: NDEF标签不可设置为只读。 | 745 746**错误码:** 747 748以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 749 750| 错误码ID | 错误信息| 751| ------- | -------| 752| 3100201 | Tag running state is abnormal in service. | 753 754**示例:** 755 756```js 757import tag from '@ohos.nfc.tag'; 758 759// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 760let canSetReadOnly : boolean = ndefTag.canSetReadOnly(); 761console.log("ndef canSetReadOnly: " + canSetReadOnly); 762``` 763 764### NdefTag.setReadOnly<sup>9+</sup> 765 766setReadOnly(): Promise\<void> 767 768将NDEF标签设置为只读,使用Promise方式作为异步方法。 769 770**需要权限:** ohos.permission.NFC_TAG 771 772**系统能力:** SystemCapability.Communication.NFC.Tag 773 774**错误码:** 775 776以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 777 778| 错误码ID | 错误信息| 779| ------- | -------| 780| 3100201 | Tag running state is abnormal in service. | 781 782**示例:** 783 784```js 785import tag from '@ohos.nfc.tag'; 786import {BusinessError} from '@ohos.base'; 787 788// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 789 790// connect the tag at first if not connected. 791if (!ndefTag.isTagConnected()) { 792 if (!ndefTag.connectTag()) { 793 console.log("ndefTag connectTag failed."); 794 return; 795 } 796} 797 798try { 799 ndefTag.setReadOnly().then(() => { 800 console.log("ndef setReadOnly Promise success."); 801 }).catch((err : BusinessError)=> { 802 console.error("ndef setReadOnly Promise err Code: ${err.code}, message: ${err.message}"); 803 }); 804} catch (busiError) { 805 console.error("ndef setReadOnly Promise catch busiError Code: ${(busiError as Businsess).code}, " + 806 "message: ${(busiError as Businsess).message}"); 807} 808``` 809 810### NdefTag.setReadOnly<sup>9+</sup> 811 812setReadOnly(callback: AsyncCallback\<void>): void 813 814将NDEF标签设置为只读,使用AsyncCallback方式作为异步方法。 815 816**需要权限:** ohos.permission.NFC_TAG 817 818**系统能力:** SystemCapability.Communication.NFC.Tag 819 820**参数:** 821 822| 参数名 | 类型 | 必填 | 说明 | 823| -------- | ----------------------- | ---- | -------------------------------------- | 824| callback | AsyncCallback\<void> | 是 | 回调函数。 | 825 826**错误码:** 827 828以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 829 830| 错误码ID | 错误信息| 831| ------- | -------| 832| 3100201 | Tag running state is abnormal in service. | 833 834**示例:** 835 836```js 837import tag from '@ohos.nfc.tag'; 838import {BusinessError} from '@ohos.base'; 839 840// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 841 842// connect the tag at first if not connected. 843if (!ndefTag.isTagConnected()) { 844 if (!ndefTag.connectTag()) { 845 console.log("ndefTag connectTag failed."); 846 return; 847 } 848} 849 850try { 851 ndefTag.setReadOnly((err : BusinessError)=> { 852 if (err) { 853 console.log("ndef setReadOnly AsyncCallback err Code: ${err.code}, message: ${err.message}"); 854 } else { 855 console.log("ndef setReadOnly AsyncCallback success."); 856 } 857 }); 858} catch (busiError) { 859 console.error("ndef setReadOnly AsyncCallback catch busiError Code: ${(busiError as Businsess).code}, " + 860 "message: ${(busiError as Businsess).message}"); 861} 862``` 863 864### NdefTag.getNdefTagTypeString<sup>9+</sup> 865 866getNdefTagTypeString(type: [tag.NfcForumType](js-apis-nfcTag.md#nfcforumtype9)): string 867 868将NFC论坛类型,转换为NFC论坛中定义的字符串描述。 869 870**系统能力:** SystemCapability.Communication.NFC.Tag 871 872**参数:** 873 874| 参数名 | 类型 | 必填 | 说明 | 875| -------- | ----------------------- | ---- | -------------------------------------- | 876| type | [tag.NfcForumType](js-apis-nfcTag.md#nfcforumtype9) | 是 | NDEF标签类型,包括NFC FORUM TYPE 1/2/3/4等。 | 877 878**返回值:** 879 880| **类型** | **说明** | 881| ------------------ | --------------------------| 882| string | NFC论坛类型的字符串描述。| 883 884**示例:** 885 886```js 887import tag from '@ohos.nfc.tag'; 888import {BusinessError} from '@ohos.base'; 889 890// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefTag' correctly. 891 892try { 893 let ndefTypeString : tag.NfcForumType = ndefTag.getNdefTagTypeString(tag.NfcForumType.NFC_FORUM_TYPE_1); 894 console.log("ndef ndefTypeString: " + ndefTypeString); 895} catch (busiError) { 896 console.error("ndef getNdefTagTypeString catch busiError Code: ${(busiError as Businsess).code}, " + 897 "message: ${(busiError as Businsess).message}"); 898} 899``` 900 901## MifareClassicTag<sup>9+</sup> 902 903MifareClassicTag提供对MIFARE Classic属性和I/O操作的访问,继承自[TagSession](js-apis-tagSession.md)。 904 905TagSession是所有NFC Tag技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 906 907以下是MifareClassicTag的独有接口。 908 909### MifareClassicTag.authenticateSector<sup>9+</sup> 910 911authenticateSector(sectorIndex: number, key: number[], isKeyA: boolean): Promise\<void> 912 913使用密钥对扇区进行身份验证,只有身份验证成功的扇区可以进行操作。使用Promise方式作为异步方法。 914 915**需要权限:** ohos.permission.NFC_TAG 916 917**系统能力:** SystemCapability.Communication.NFC.Tag 918 919**参数:** 920 921| 参数名 | 类型 | 必填 | 说明 | 922| -------- | ----------------------- | ---- | -------------------------------------- | 923| sectorIndex | number | 是 | 待验证的扇区索引,从0开始。 | 924| key | number[]| 是 | 用于扇区验证的密钥(6字节)。 | 925| isKeyA | boolean | 是 | isKeyA标志。true 表示KeyA,false 表示KeyB。| 926 927**错误码:** 928 929以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 930 931| 错误码ID | 错误信息| 932| ------- | -------| 933| 3100201 | Tag running state is abnormal in service. | 934 935**示例:** 936 937```js 938import tag from '@ohos.nfc.tag'; 939import {BusinessError} from '@ohos.base'; 940 941// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 942 943// connect the tag at first if not connected. 944if (!mifareClassic.isTagConnected()) { 945 if (!mifareClassic.connectTag()) { 946 console.log("mifareClassic connectTag failed."); 947 return; 948 } 949} 950 951try { 952 let sectorIndex = 1; // change it to be correct index. 953 let key = [0x01, 0x02, 0x03, 0x04, 0x05, 0x06] // MUST be 6 bytes, change it to be correct key. 954 mifareClassic.authenticateSector(sectorIndex, key, true).then(() => { 955 console.log("mifareClassic authenticateSector Promise success."); 956 }).catch((err : BusinessError)=> { 957 console.error("mifareClassic authenticateSector Promise errCode: ${err.code}, " + "message: ${err.message}"); 958 }); 959} catch (busiError) { 960 console.error("mifareClassic authenticateSector Promise catch busiError Code: ${(busiError as Businsess).code}, " + 961 "message: ${(busiError as Businsess).message}"); 962} 963``` 964 965### MifareClassicTag.authenticateSector<sup>9+</sup> 966 967authenticateSector(sectorIndex: number, key: number[], isKeyA: boolean, callback: AsyncCallback\<void>): void 968 969使用密钥对扇区进行身份验证,只有身份验证成功的扇区可以进行操作。使用AsyncCallback方式作为异步方法。 970 971**需要权限:** ohos.permission.NFC_TAG 972 973**系统能力:** SystemCapability.Communication.NFC.Tag 974 975**参数:** 976 977| 参数名 | 类型 | 必填 | 说明 | 978| -------- | ----------------------- | ---- | -------------------------------------- | 979| sectorIndex | number | 是 | 待验证的扇区索引,从0开始。 | 980| key | number[]| 是 | 用于扇区验证的密钥(6字节)。 | 981| isKeyA | boolean | 是 | isKeyA标志。true 表示KeyA,false 表示KeyB。| 982| callback | AsyncCallback\<void> | 是 | 以callback形式异步返回扇区验证结果。| 983 984**错误码:** 985 986以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 987 988| 错误码ID | 错误信息| 989| ------- | -------| 990| 3100201 | Tag running state is abnormal in service. | 991 992**示例:** 993```js 994import tag from '@ohos.nfc.tag'; 995import {BusinessError} from '@ohos.base'; 996 997// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 998 999// connect the tag at first if not connected. 1000if (!mifareClassic.isTagConnected()) { 1001 if (!mifareClassic.connectTag()) { 1002 console.log("mifareClassic connectTag failed."); 1003 return; 1004 } 1005} 1006 1007try { 1008 let sectorIndex = 1; // change it to be correct index. 1009 let key = [0x01, 0x02, 0x03, 0x04, 0x05, 0x06] // MUST be 6 bytes, change it to be correct key. 1010 mifareClassic.authenticateSector(sectorIndex, key, true, (err : BusinessError)=> { 1011 if (err) { 1012 console.log("mifareClassic authenticateSector AsyncCallback errCode: ${err.code}, message: ${err.message}"); 1013 } else { 1014 console.log("mifareClassic authenticateSector AsyncCallback success."); 1015 } 1016 }); 1017} catch (busiError) { 1018 console.error("mifareClassic authenticateSector AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 1019 "message: ${(busiError as Businsess).message}"); 1020} 1021``` 1022 1023### MifareClassicTag.readSingleBlock<sup>9+</sup> 1024 1025readSingleBlock(blockIndex: number): Promise\<number[]> 1026 1027读取标签中一个块存储的内容,一个块大小为16字节。使用Promise方式作为异步方法。 1028 1029**需要权限:** ohos.permission.NFC_TAG 1030 1031**系统能力:** SystemCapability.Communication.NFC.Tag 1032 1033**参数:** 1034 1035| 参数名 | 类型 | 必填 | 说明 | 1036| -------- | ----------------------- | ---- | -------------------------------------- | 1037| blockIndex | number | 是 | 要读取的块索引,从0开始。 | 1038 1039**返回值:** 1040 1041| **类型** | **说明** | 1042| ------------------ | --------------------------| 1043| Promise\<number[]> | 以Promise形式返回读取的块数据。 | 1044 1045**错误码:** 1046 1047以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1048 1049| 错误码ID | 错误信息| 1050| ------- | -------| 1051| 3100201 | Tag running state is abnormal in service. | 1052 1053**示例:** 1054 1055```js 1056import tag from '@ohos.nfc.tag'; 1057import {BusinessError} from '@ohos.base'; 1058 1059// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1060 1061// connect the tag at first if not connected. 1062if (!mifareClassic.isTagConnected()) { 1063 if (!mifareClassic.connectTag()) { 1064 console.log("mifareClassic connectTag failed."); 1065 return; 1066 } 1067} 1068 1069try { 1070 let blockIndex = 1; // change it to be correct index. 1071 mifareClassic.readSingleBlock(blockIndex).then((data : number[]) => { 1072 console.log("mifareClassic readSingleBlock Promise data: " + data); 1073 }).catch((err : BusinessError)=> { 1074 console.error("mifareClassic readSingleBlock Promise errCode: ${err.code}, message: ${err.message}"); 1075 }); 1076} catch (busiError) { 1077 console.error("mifareClassic readSingleBlock Promise catch busiError Code: ${(busiError as Businsess).code}, " + 1078 "message: ${(busiError as Businsess).message}"); 1079} 1080``` 1081 1082### MifareClassicTag.readSingleBlock<sup>9+</sup> 1083 1084readSingleBlock(blockIndex: number, callback: AsyncCallback\<number[]>): void 1085 1086读取标签中一个块存储的内容,一个块大小为16字节。使用AsyncCallback方式作为异步方法。 1087 1088**需要权限:** ohos.permission.NFC_TAG 1089 1090**系统能力:** SystemCapability.Communication.NFC.Tag 1091 1092**参数:** 1093 1094| 参数名 | 类型 | 必填 | 说明 | 1095| -------- | ----------------------- | ---- | -------------------------------------- | 1096| blockIndex | number | 是 | 要读取的块索引,从0开始。 | 1097| callback | AsyncCallback\<number[]> | 是 |以callback形式异步返回读取到的块数据。 | 1098 1099**错误码:** 1100 1101以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1102 1103| 错误码ID | 错误信息| 1104| ------- | -------| 1105| 3100201 | Tag running state is abnormal in service. | 1106 1107**示例:** 1108 1109```js 1110import tag from '@ohos.nfc.tag'; 1111import {BusinessError} from '@ohos.base'; 1112 1113// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1114 1115// connect the tag at first if not connected. 1116if (!mifareClassic.isTagConnected()) { 1117 if (!mifareClassic.connectTag()) { 1118 console.log("mifareClassic connectTag failed."); 1119 return; 1120 } 1121} 1122 1123try { 1124 let blockIndex = 1; // change it to be correct index. 1125 mifareClassic.readSingleBlock(blockIndex, (err : BusinessError, data : number[])=> { 1126 if (err) { 1127 console.log("mifareClassic readSingleBlock AsyncCallback err: " + err); 1128 } else { 1129 console.log("mifareClassic readSingleBlock AsyncCallback data: " + data); 1130 } 1131 }); 1132} catch (busiError) { 1133 console.error("mifareClassic readSingleBlock AsyncCallback catch busiError Code: ${(busiError as Businsess).code}, " + 1134 "message: ${(busiError as Businsess).message}"); 1135} 1136``` 1137 1138### MifareClassicTag.writeSingleBlock<sup>9+</sup> 1139 1140writeSingleBlock(blockIndex: number, data: number[]): Promise\<void> 1141 1142向标签中一个块存储写入内容,一个块大小为16字节。使用Promise方式作为异步方法。 1143 1144**需要权限:** ohos.permission.NFC_TAG 1145 1146**系统能力:** SystemCapability.Communication.NFC.Tag 1147 1148**参数:** 1149 1150| 参数名 | 类型 | 必填 | 说明 | 1151| -------- | ----------------------- | ---- | -------------------------------------- | 1152| blockIndex | number | 是 | 要写入的块索引,从0开始。 | 1153| data | number[] | 是 | 要写入的数据,大小必须是16个字节。 | 1154 1155**错误码:** 1156 1157以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1158 1159| 错误码ID | 错误信息| 1160| ------- | -------| 1161| 3100201 | Tag running state is abnormal in service. | 1162 1163**示例:** 1164 1165```js 1166import tag from '@ohos.nfc.tag'; 1167import {BusinessError} from '@ohos.base'; 1168 1169// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1170 1171// connect the tag at first if not connected. 1172if (!mifareClassic.isTagConnected()) { 1173 if (!mifareClassic.connectTag()) { 1174 console.log("mifareClassic connectTag failed."); 1175 return; 1176 } 1177} 1178 1179try { 1180 let blockIndex = 1; // change it to be correct index. 1181 let rawData = [0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 1182 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10]; // MUST be 16 bytes, change it to be correct data. 1183 mifareClassic.writeSingleBlock(blockIndex, rawData).then(() => { 1184 console.log("mifareClassic writeSingleBlock Promise success."); 1185 }).catch((err : BusinessError)=> { 1186 console.error("mifareClassic writeSingleBlock Promise errCode: ${err.code}, message: ${err.message}"); 1187 }); 1188} catch (busiError) { 1189 console.error("mifareClassic writeSingleBlock Promise catch busiError Code: ${(busiError as Businsess).code}, " + 1190 "message: ${(busiError as Businsess).message}"); 1191} 1192``` 1193 1194### MifareClassicTag.writeSingleBlock<sup>9+</sup> 1195 1196writeSingleBlock(blockIndex: number, data: number[], callback: AsyncCallback\<void>): void 1197 1198向标签中一个块存储写入内容,一个块大小为16字节。使用AsyncCallback方式作为异步方法。 1199 1200**需要权限:** ohos.permission.NFC_TAG 1201 1202**系统能力:** SystemCapability.Communication.NFC.Tag 1203 1204**参数:** 1205 1206| 参数名 | 类型 | 必填 | 说明 | 1207| -------- | ----------------------- | ---- | -------------------------------------- | 1208| blockIndex | number | 是 | 要写入的块索引,从0开始。 | 1209| data | number[] | 是 | 要写入的数据,大小必须是16个字节。 | 1210| callback | AsyncCallback\<void> | 是 | 以callback形式异步返回块操作结果。 | 1211 1212**错误码:** 1213 1214以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1215 1216| 错误码ID | 错误信息| 1217| ------- | -------| 1218| 3100201 | Tag running state is abnormal in service. | 1219 1220**示例:** 1221 1222```js 1223import tag from '@ohos.nfc.tag'; 1224import {BusinessError} from '@ohos.base'; 1225 1226// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1227 1228// connect the tag at first if not connected. 1229if (!mifareClassic.isTagConnected()) { 1230 if (!mifareClassic.connectTag()) { 1231 console.log("mifareClassic connectTag failed."); 1232 return; 1233 } 1234} 1235 1236try { 1237 let blockIndex = 1; // change it to be correct index. 1238 let rawData = [0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 1239 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10]; // MUST be 16 bytes, change it to be correct data. 1240 mifareClassic.writeSingleBlock(blockIndex, rawData, (err : BusinessError)=> { 1241 if (err) { 1242 console.log("mifareClassic writeSingleBlock AsyncCallback err Code: ${err.code}, message: ${err.message}"); 1243 } else { 1244 console.log("mifareClassic writeSingleBlock AsyncCallback success."); 1245 } 1246 }); 1247} catch (busiError) { 1248 console.error("mifareClassic writeSingleBlock AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 1249 "message: ${(busiError as Businsess).message}"); 1250} 1251``` 1252 1253### MifareClassicTag.incrementBlock<sup>9+</sup> 1254 1255incrementBlock(blockIndex: number, value: number): Promise\<void> 1256 1257对指定块的内容,增加指定的数值,并将结果存储在内部传输缓冲器中。使用Promise方式作为异步方法。 1258 1259**需要权限:** ohos.permission.NFC_TAG 1260 1261**系统能力:** SystemCapability.Communication.NFC.Tag 1262 1263**参数:** 1264 1265| 参数名 | 类型 | 必填 | 说明 | 1266| -------- | ----------------------- | ---- | -------------------------------------- | 1267| blockIndex | number | 是 | 要指定增加的块索引,从0开始。 | 1268| value | number | 是 | 要指定增加的数据,非负数。 | 1269 1270**错误码:** 1271 1272以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1273 1274| 错误码ID | 错误信息| 1275| ------- | -------| 1276| 3100201 | Tag running state is abnormal in service. | 1277 1278**示例:** 1279 1280```js 1281import tag from '@ohos.nfc.tag'; 1282import {BusinessError} from '@ohos.base'; 1283 1284// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1285 1286// connect the tag at first if not connected. 1287if (!mifareClassic.isTagConnected()) { 1288 if (!mifareClassic.connectTag()) { 1289 console.log("mifareClassic connectTag failed."); 1290 return; 1291 } 1292} 1293 1294try { 1295 let blockIndex = 1; // change it to be correct index. 1296 let value = 0x20; // change it to be correct data. 1297 mifareClassic.incrementBlock(blockIndex, value).then(() => { 1298 console.log("mifareClassic incrementBlock Promise success."); 1299 }).catch((err : BusinessError)=> { 1300 console.error("mifareClassic incrementBlock Promise err Code: ${err.code}, message: ${err.message}"); 1301 }); 1302} catch (busiError) { 1303 console.error("mifareClassic incrementBlock Promise catch Code: ${(busiError as Businsess).code}, " + 1304 "message: ${(busiError as Businsess).message}"); 1305} 1306``` 1307 1308### MifareClassicTag.incrementBlock<sup>9+</sup> 1309 1310incrementBlock(blockIndex: number, value: number, callback: AsyncCallback\<void>): void 1311 1312对指定块的内容,增加指定的数值,并将结果存储在内部传输缓冲器中。使用AsyncCallback方式作为异步方法。 1313 1314**需要权限:** ohos.permission.NFC_TAG 1315 1316**系统能力:** SystemCapability.Communication.NFC.Tag 1317 1318**参数:** 1319 1320| 参数名 | 类型 | 必填 | 说明 | 1321| -------- | ----------------------- | ---- | -------------------------------------- | 1322| blockIndex | number | 是 | 要被运算的块索引,从0开始。 | 1323| value | number | 是 | 要增加的数值,非负数。 | 1324| callback | AsyncCallback\<void> | 是 | 以callback形式异步返回块操作结果。。 | 1325 1326**错误码:** 1327 1328以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1329 1330| 错误码ID | 错误信息| 1331| ------- | -------| 1332| 3100201 | Tag running state is abnormal in service. | 1333 1334**示例:** 1335 1336```js 1337import tag from '@ohos.nfc.tag'; 1338import {BusinessError} from '@ohos.base'; 1339 1340// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1341 1342// connect the tag at first if not connected. 1343if (!mifareClassic.isTagConnected()) { 1344 if (!mifareClassic.connectTag()) { 1345 console.log("mifareClassic connectTag failed."); 1346 return; 1347 } 1348} 1349 1350try { 1351 let blockIndex = 1; // change it to be correct index. 1352 let value = 0x20; // change it to be correct data. 1353 mifareClassic.incrementBlock(blockIndex, value, (err : BusinessError)=> { 1354 if (err) { 1355 console.log("mifareClassic incrementBlock AsyncCallback err Code: ${err.code}, message: ${err.message}"); 1356 } else { 1357 console.log("mifareClassic incrementBlock AsyncCallback success."); 1358 } 1359 }); 1360} catch (busiError) { 1361 console.error("mifareClassic incrementBlock AsyncCallback catch busiError Code: ${(busiError as Businsess).code}, " + 1362 "message: ${(busiError as Businsess).message}"); 1363} 1364``` 1365 1366### MifareClassicTag.decrementBlock<sup>9+</sup> 1367 1368decrementBlock(blockIndex: number, value: number): Promise\<void> 1369 1370对指定块的内容,减少指定的数值,并将结果存储在内部传输缓冲器中。使用Promise方式作为异步方法。 1371 1372**需要权限:** ohos.permission.NFC_TAG 1373 1374**系统能力:** SystemCapability.Communication.NFC.Tag 1375 1376**参数:** 1377 1378| 参数名 | 类型 | 必填 | 说明 | 1379| -------- | ----------------------- | ---- | -------------------------------------- | 1380| blockIndex | number | 是 | 要被运算的块索引,从0开始。 | 1381| value | number | 是 | 要减少的数值,非负数。 | 1382 1383**错误码:** 1384 1385以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1386 1387| 错误码ID | 错误信息| 1388| ------- | -------| 1389| 3100201 | Tag running state is abnormal in service. | 1390 1391**示例:** 1392 1393```js 1394import tag from '@ohos.nfc.tag'; 1395import {BusinessError} from '@ohos.base'; 1396 1397// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1398 1399// connect the tag at first if not connected. 1400if (!mifareClassic.isTagConnected()) { 1401 if (!mifareClassic.connectTag()) { 1402 console.log("mifareClassic connectTag failed."); 1403 return; 1404 } 1405} 1406 1407try { 1408 let blockIndex = 1; // change it to be correct index. 1409 let value = 0x20; // change it to be correct data. 1410 mifareClassic.decrementBlock(blockIndex, value).then(() => { 1411 console.log("mifareClassic decrementBlock Promise success."); 1412 }).catch((err : BusinessError)=> { 1413 console.error("mifareClassic decrementBlock Promise errCode: ${err.code}, message: ${err.message}"); 1414 }); 1415} catch (busiError) { 1416 console.error("mifareClassic decrementBlock Promise catch busiError: Code: ${(busiError as Businsess).code}, " + 1417 "message: ${(busiError as Businsess).message}"); 1418} 1419``` 1420 1421### MifareClassicTag.decrementBlock<sup>9+</sup> 1422 1423decrementBlock(blockIndex: number, value: number, callback: AsyncCallback\<void>): void 1424 1425对指定块的内容,减少指定的数值。使用AsyncCallback方式作为异步方法。 1426 1427**需要权限:** ohos.permission.NFC_TAG 1428 1429**系统能力:** SystemCapability.Communication.NFC.Tag 1430 1431**参数:** 1432 1433| 参数名 | 类型 | 必填 | 说明 | 1434| -------- | ----------------------- | ---- | -------------------------------------- | 1435| blockIndex | number | 是 | 要被运算的块索引,从0开始。 | 1436| value | number | 是 | 要减少的数值,非负数。 | 1437| callback | AsyncCallback\<void> | 是 | 以callback形式异步返回块操作结果。 | 1438 1439**错误码:** 1440 1441以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1442 1443| 错误码ID | 错误信息| 1444| ------- | -------| 1445| 3100201 | Tag running state is abnormal in service. | 1446 1447**示例:** 1448 1449```js 1450import tag from '@ohos.nfc.tag'; 1451import {BusinessError} from '@ohos.base'; 1452 1453// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1454 1455// connect the tag at first if not connected. 1456if (!mifareClassic.isTagConnected()) { 1457 if (!mifareClassic.connectTag()) { 1458 console.log("mifareClassic connectTag failed."); 1459 return; 1460 } 1461} 1462 1463try { 1464 let blockIndex = 1; // change it to be correct index. 1465 let value = 0x20; // change it to be correct data. 1466 mifareClassic.decrementBlock(blockIndex, value, (err : BusinessError)=> { 1467 if (err) { 1468 console.log("mifareClassic decrementBlock AsyncCallback errCode: ${err.code}, message: ${err.message}"); 1469 } else { 1470 console.log("mifareClassic decrementBlock AsyncCallback success."); 1471 } 1472 }); 1473} catch (busiError) { 1474 console.error("mifareClassic decrementBlock AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 1475 "message: ${(busiError as Businsess).message}"); 1476} 1477``` 1478 1479### MifareClassicTag.transferToBlock<sup>9+</sup> 1480 1481transferToBlock(blockIndex: number): Promise\<void> 1482 1483将临时寄存器的值转移到指定的块。使用Promise方式作为异步方法。 1484 1485**需要权限:** ohos.permission.NFC_TAG 1486 1487**系统能力:** SystemCapability.Communication.NFC.Tag 1488 1489**参数:** 1490 1491| 参数名 | 类型 | 必填 | 说明 | 1492| -------- | ----------------------- | ---- | -------------------------------------- | 1493| blockIndex | number | 是 | 被操作的块的索引,从0开始。 | 1494 1495**错误码:** 1496 1497以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1498 1499| 错误码ID | 错误信息| 1500| ------- | -------| 1501| 3100201 | Tag running state is abnormal in service. | 1502 1503**示例:** 1504 1505```js 1506import tag from '@ohos.nfc.tag'; 1507import {BusinessError} from '@ohos.base'; 1508 1509// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1510 1511// connect the tag at first if not connected. 1512if (!mifareClassic.isTagConnected()) { 1513 if (!mifareClassic.connectTag()) { 1514 console.log("mifareClassic connectTag failed."); 1515 return; 1516 } 1517} 1518 1519try { 1520 let blockIndex = 1; // change it to be correct index. 1521 mifareClassic.transferToBlock(blockIndex).then(() => { 1522 console.log("mifareClassic transferToBlock Promise success."); 1523 }).catch((err : BusinessError)=> { 1524 console.error("mifareClassic transferToBlock Promise err Code: ${err.code}, message: ${err.message}"); 1525 }); 1526} catch (busiError) { 1527 console.error("mifareClassic transferToBlock Promise catch Code: ${(busiError as Businsess).code}, " + 1528 "message: ${(busiError as Businsess).message}"); 1529} 1530``` 1531 1532### MifareClassicTag.transferToBlock<sup>9+</sup> 1533 1534transferToBlock(blockIndex: number, callback: AsyncCallback\<void>): void 1535 1536将临时寄存器的值转移到指定的块。使用AsyncCallback方式作为异步方法。 1537 1538**需要权限:** ohos.permission.NFC_TAG 1539 1540**系统能力:** SystemCapability.Communication.NFC.Tag 1541 1542**参数:** 1543 1544| 参数名 | 类型 | 必填 | 说明 | 1545| -------- | ----------------------- | ---- | -------------------------------------- | 1546| blockIndex | number | 是 | 被操作的块的索引,从0开始。 | 1547| callback | AsyncCallback\<void> | 是 | 以callback形式异步返回块操作结果。 | 1548 1549**错误码:** 1550 1551以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1552 1553| 错误码ID | 错误信息| 1554| ------- | -------| 1555| 3100201 | Tag running state is abnormal in service. | 1556 1557**示例:** 1558 1559```js 1560import tag from '@ohos.nfc.tag'; 1561import {BusinessError} from '@ohos.base'; 1562 1563// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1564 1565// connect the tag at first if not connected. 1566if (!mifareClassic.isTagConnected()) { 1567 if (!mifareClassic.connectTag()) { 1568 console.log("mifareClassic connectTag failed."); 1569 return; 1570 } 1571} 1572 1573try { 1574 let blockIndex = 1; // change it to be correct index. 1575 mifareClassic.transferToBlock(blockIndex, (err : BusinessError)=> { 1576 if (err) { 1577 console.error("mifareClassic transferToBlock AsyncCallback errCode: ${err.code}, message: ${err.message}"); 1578 } else { 1579 console.log("mifareClassic transferToBlock AsyncCallback success."); 1580 } 1581 }); 1582} catch (busiError) { 1583 console.error("mifareClassic transferToBlock AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 1584 "message: ${(busiError as Businsess).message}"); 1585} 1586``` 1587 1588### MifareClassicTag.restoreFromBlock<sup>9+</sup> 1589 1590restoreFromBlock(blockIndex: number): Promise\<void> 1591 1592将指定块的值复制到临时寄存器。使用Promise方式作为异步方法。 1593 1594**需要权限:** ohos.permission.NFC_TAG 1595 1596**系统能力:** SystemCapability.Communication.NFC.Tag 1597 1598**参数:** 1599 1600| 参数名 | 类型 | 必填 | 说明 | 1601| -------- | ----------------------- | ---- | -------------------------------------- | 1602| blockIndex | number | 是 | 被操作的块的索引,从0开始。| 1603 1604**错误码:** 1605 1606以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1607 1608| 错误码ID | 错误信息| 1609| ------- | -------| 1610| 3100201 | Tag running state is abnormal in service. | 1611 1612**示例:** 1613 1614```js 1615import tag from '@ohos.nfc.tag'; 1616import {BusinessError} from '@ohos.base'; 1617 1618// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1619 1620// connect the tag at first if not connected. 1621if (!mifareClassic.isTagConnected()) { 1622 if (!mifareClassic.connectTag()) { 1623 console.log("mifareClassic connectTag failed."); 1624 return; 1625 } 1626} 1627 1628try { 1629 let blockIndex = 1; // change it to be correct index. 1630 mifareClassic.restoreFromBlock(blockIndex).then(() => { 1631 console.log("mifareClassic restoreFromBlock Promise success."); 1632 }).catch((err : BusinessError)=> { 1633 console.error("mifareClassic restoreFromBlock Promise errCode: ${err.code}, message: ${err.message}"); 1634 }); 1635} catch (busiError) { 1636 console.error("mifareClassic restoreFromBlock Promise catch busiError Code: ${(busiError as Businsess).code}, " + 1637 "message: ${(busiError as Businsess).message}"); 1638} 1639``` 1640 1641### MifareClassicTag.restoreFromBlock<sup>9+</sup> 1642 1643restoreFromBlock(blockIndex: number, callback: AsyncCallback\<void>): void 1644 1645将指定块的值复制到临时寄存器。使用AsyncCallback方式作为异步方法。 1646 1647**需要权限:** ohos.permission.NFC_TAG 1648 1649**系统能力:** SystemCapability.Communication.NFC.Tag 1650 1651**参数:** 1652 1653| 参数名 | 类型 | 必填 | 说明 | 1654| -------- | ----------------------- | ---- | -------------------------------------- | 1655| blockIndex | number | 是 | 被操作的块的索引,从0开始。 | 1656| callback | AsyncCallback\<void> | 是 | 以callback形式异步返回块操作结果。| 1657 1658**错误码:** 1659 1660以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1661 1662| 错误码ID | 错误信息| 1663| ------- | -------| 1664| 3100201 | Tag running state is abnormal in service. | 1665 1666**示例:** 1667 1668```js 1669import tag from '@ohos.nfc.tag'; 1670import {BusinessError} from '@ohos.base'; 1671 1672// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1673 1674// connect the tag at first if not connected. 1675if (!mifareClassic.isTagConnected()) { 1676 if (!mifareClassic.connectTag()) { 1677 console.log("mifareClassic connectTag failed."); 1678 return; 1679 } 1680} 1681 1682try { 1683 let blockIndex = 1; // change it to be correct index. 1684 mifareClassic.restoreFromBlock(blockIndex, (err : BusinessError)=> { 1685 if (err) { 1686 console.log("mifareClassic restoreFromBlock AsyncCallback err Code: ${err.code}, message: ${err.message}"); 1687 } else { 1688 console.log("mifareClassic restoreFromBlock AsyncCallback success."); 1689 } 1690 }); 1691} catch (busiError) { 1692 console.error("mifareClassic restoreFromBlock AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 1693 "message: ${(busiError as Businsess).message}"); 1694} 1695``` 1696 1697### MifareClassicTag.getSectorCount<sup>9+</sup> 1698 1699getSectorCount(): number 1700 1701获取MIFARE Classic标签中的扇区数。 1702 1703**系统能力:** SystemCapability.Communication.NFC.Tag 1704 1705**返回值:** 1706 1707| **类型** | **说明** | 1708| ------------------ | --------------------------| 1709| number | 标签中的扇区数量。| 1710 1711**示例:** 1712 1713```js 1714import tag from '@ohos.nfc.tag'; 1715import {BusinessError} from '@ohos.base'; 1716 1717// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1718let sectorCount : number = mifareClassic.getSectorCount(); 1719console.log("mifareClassic sectorCount: " + sectorCount); 1720``` 1721 1722### MifareClassicTag.getBlockCountInSector<sup>9+</sup> 1723 1724getBlockCountInSector(sectorIndex: number): number 1725 1726获取指定扇区中的块数。 1727 1728**系统能力:** SystemCapability.Communication.NFC.Tag 1729 1730**参数:** 1731 1732| 参数名 | 类型 | 必填 | 说明 | 1733| -------- | ----------------------- | ---- | -------------------------------------- | 1734| sectorIndex | number | 是 | 扇区序号,从0开始。| 1735 1736**返回值:** 1737 1738| **类型** | **说明** | 1739| ------------------ | --------------------------| 1740| number | 该扇区内的块数量。| 1741 1742**示例:** 1743 1744```js 1745import tag from '@ohos.nfc.tag'; 1746import {BusinessError} from '@ohos.base'; 1747 1748// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1749 1750try { 1751 let sectorIndex = 1; // change it to be correct index. 1752 let blockCnt : number = mifareClassic.getBlockCountInSector(sectorIndex); 1753 console.log("mifareClassic blockCnt: " + blockCnt); 1754} catch (busiError) { 1755 console.error("mifareClassic getBlockCountInSector catch busiError Code: ${(busiError as Businsess).code}, " + 1756 "message: ${(busiError as Businsess).message}"); 1757} 1758``` 1759 1760### MifareClassicTag.getType<sup>9+</sup> 1761 1762getType(): [tag.MifareClassicType](js-apis-nfcTag.md#mifareclassictype9) 1763 1764获取MIFARE Classic标签的类型。 1765 1766**系统能力:** SystemCapability.Communication.NFC.Tag 1767 1768**返回值:** 1769 1770| **类型** | **说明** | 1771| ------------------ | --------------------------| 1772| [tag.MifareClassicType](js-apis-nfcTag.md#mifareclassictype9) | MifareClassic标签的类型。| 1773 1774**示例:** 1775 1776```js 1777import tag from '@ohos.nfc.tag'; 1778 1779// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1780let getType : tag.MifareClassicType = mifareClassic.getType(); 1781console.log("mifareClassic getType: " + getType); 1782``` 1783 1784### MifareClassicTag.getTagSize<sup>9+</sup> 1785 1786getTagSize(): number 1787 1788获取标签的存储空间大小,具体请参见[MifareClassicSize](js-apis-nfcTag.md#mifareclassicsize9)。 1789 1790**系统能力:** SystemCapability.Communication.NFC.Tag 1791 1792**返回值:** 1793 1794| **类型** | **说明** | 1795| ------------------ | --------------------------| 1796| number | 标签的大小,单位为字节,请参见[MifareClassicSize](js-apis-nfcTag.md#mifareclassicsize9)。| 1797 1798**示例:** 1799 1800```js 1801import tag from '@ohos.nfc.tag'; 1802import {BusinessError} from '@ohos.base'; 1803 1804// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1805let tagSize : number = mifareClassic.getTagSize(); 1806console.log("mifareClassic tagSize: " + tagSize); 1807``` 1808 1809### MifareClassicTag.isEmulatedTag<sup>9+</sup> 1810 1811isEmulatedTag(): boolean 1812 1813检查标签是不是被模拟的。 1814 1815**系统能力:** SystemCapability.Communication.NFC.Tag 1816 1817**返回值:** 1818 1819| **类型** | **说明** | 1820| ------------------ | --------------------------| 1821| boolean |检查结果,true: 是;false:否。 | 1822 1823**示例:** 1824 1825```js 1826import tag from '@ohos.nfc.tag'; 1827import {BusinessError} from '@ohos.base'; 1828 1829// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1830let isEmulatedTag : boolean = mifareClassic.isEmulatedTag(); 1831console.log("mifareClassic isEmulatedTag: " + isEmulatedTag); 1832``` 1833 1834### MifareClassicTag.getBlockIndex<sup>9+</sup> 1835 1836getBlockIndex(sectorIndex: number): number 1837 1838获取特定扇区的第一个块的序号。 1839 1840**系统能力:** SystemCapability.Communication.NFC.Tag 1841 1842**参数:** 1843 1844| 参数名 | 类型 | 必填 | 说明 | 1845| -------- | ----------------------- | ---- | -------------------------------------- | 1846| sectorIndex | number | 是 | 扇区序号,从0开始。 | 1847 1848**返回值:** 1849 1850| **类型** | **说明** | 1851| ------------------ | --------------------------| 1852| number | 该扇区内的第一个块的序号,从0开始。 | 1853 1854**示例:** 1855 1856```js 1857import tag from '@ohos.nfc.tag'; 1858import {BusinessError} from '@ohos.base'; 1859 1860// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1861 1862try { 1863 let sectorIndex = 1; // change it to be correct index. 1864 let blockIndex : number = mifareClassic.getBlockIndex(sectorIndex); 1865 console.log("mifareClassic blockIndex: " + blockIndex); 1866} catch (busiError) { 1867 console.error("mifareClassic getBlockIndex catch busiError Code: ${(busiError as Businsess).code}, " + 1868 "message: ${(busiError as Businsess).message}"); 1869} 1870``` 1871 1872### MifareClassicTag.getSectorIndex<sup>9+</sup> 1873 1874getSectorIndex(blockIndex: number): number 1875 1876获取包含指定块号的扇区序号。 1877 1878**系统能力:** SystemCapability.Communication.NFC.Tag 1879 1880**参数:** 1881 1882| 参数名 | 类型 | 必填 | 说明 | 1883| -------- | ----------------------- | ---- | -------------------------------------- | 1884| blockIndex | number | 是 | 块序号,从0开始。 | 1885 1886**返回值:** 1887 1888| **类型** | **说明** | 1889| ------------------ | --------------------------| 1890| number | 扇区序号,从0开始。 | 1891 1892**示例:** 1893 1894```js 1895import tag from '@ohos.nfc.tag'; 1896import {BusinessError} from '@ohos.base'; 1897 1898// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareClassic' correctly. 1899 1900try { 1901 let blockIndex = 1; // change it to be correct index. 1902 let sectorIndex : number = mifareClassic.getSectorIndex(blockIndex); 1903 console.log("mifareClassic sectorIndex: " + sectorIndex); 1904} catch (busiError) { 1905 console.error("mifareClassic getSectorIndex catch busiError Code: ${(busiError as Businsess).code}, " + 1906 "message: ${(busiError as Businsess).message}"); 1907} 1908``` 1909 1910## MifareUltralightTag<sup>9+</sup> 1911 1912MifareUltralightTag 提供对MIFARE Ultralight属性和I/O操作的访问,继承自TagSession。 1913 1914TagSession是所有NFC Tag技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 1915 1916以下是MifareUltralightTag的独有接口。 1917 1918### MifareUltralightTag.readMultiplePages<sup>9+</sup> 1919 1920readMultiplePages(pageIndex: number): Promise\<number[]> 1921 1922读取标签的4页数据,共16字节的数据。每个页面数据大小为4字节。使用Promise方式作为异步方法。 1923 1924**需要权限:** ohos.permission.NFC_TAG 1925 1926**系统能力:** SystemCapability.Communication.NFC.Tag 1927 1928**参数:** 1929 1930| 参数名 | 类型 | 必填 | 说明 | 1931| -------- | ----------------------- | ---- | ------------------------------ | 1932| pageIndex | number | 是 | 要读取页面的索引,从0开始。 | 1933 1934**返回值:** 1935 1936| **类型** | **说明** | 1937| ------------------ | --------------------------| 1938| Promise\<number[]> | 以Promise形式返回读取的4页的数据,共16字节。 | 1939 1940**错误码:** 1941 1942以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1943 1944| 错误码ID | 错误信息| 1945| ------- | -------| 1946| 3100201 | Tag running state is abnormal in service. | 1947 1948**示例:** 1949 1950```js 1951 1952import tag from '@ohos.nfc.tag'; 1953import {BusinessError} from '@ohos.base'; 1954 1955// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareUltralight' correctly. 1956 1957// connect the tag at first if not connected. 1958if (!mifareUltralight.isTagConnected()) { 1959 if (!mifareUltralight.connectTag()) { 1960 console.log("mifareUltralight connectTag failed."); 1961 return; 1962 } 1963} 1964 1965try { 1966 let pageIndex = 1; // change it to be correct index. 1967 mifareUltralight.readMultiplePages(pageIndex).then((data : number[]) => { 1968 console.log("mifareUltralight readMultiplePages Promise data = " + data); 1969 }).catch((err : BusinessError)=> { 1970 console.error("mifareUltralight readMultiplePages Promise Code: ${err.code}, message: ${err.message}"); 1971 }); 1972} catch (busiError) { 1973 console.error("mifareUltralight readMultiplePages Promise catch busiError Code: ${(busiError as Businsess).code}, " + 1974 "message: ${(busiError as Businsess).message}"); 1975} 1976``` 1977 1978### MifareUltralightTag.readMultiplePages<sup>9+</sup> 1979 1980readMultiplePages(pageIndex: number, callback: AsyncCallback\<number[]>): void 1981 1982读取标签的4页数据,共16字节的数据。每个页面数据大小为4字节。使用AsyncCallback方式作为异步方法。 1983 1984**需要权限:** ohos.permission.NFC_TAG 1985 1986**系统能力:** SystemCapability.Communication.NFC.Tag 1987 1988**参数:** 1989 1990| 参数名 | 类型 | 必填 | 说明 | 1991| -------- | ----------------------- | ---- | -------------------------------------- | 1992| pageIndex | number | 是 | 要读取页面的索引,从0开始。 | 1993| callback | AsyncCallback\<number[]> | 是 | 以callback形式异步返回页操作结果。返回读取到的数据,共16字节。 | 1994 1995**错误码:** 1996 1997以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 1998 1999| 错误码ID | 错误信息| 2000| ------- | -------| 2001| 3100201 | Tag running state is abnormal in service. | 2002 2003**示例:** 2004 2005```js 2006import tag from '@ohos.nfc.tag'; 2007import {BusinessError} from '@ohos.base'; 2008 2009// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareUltralight' correctly. 2010 2011// connect the tag at first if not connected. 2012if (!mifareUltralight.isTagConnected()) { 2013 if (!mifareUltralight.connectTag()) { 2014 console.log("mifareUltralight connectTag failed."); 2015 return; 2016 } 2017} 2018 2019try { 2020 let pageIndex = 1; // change it to be correct index. 2021 mifareUltralight.readMultiplePages(pageIndex, (err : BusinessError, data : number[])=> { 2022 if (err) { 2023 console.log("mifareUltralight readMultiplePages AsyncCallback Code: ${err.code}, message: ${err.message}"); 2024 } else { 2025 console.log("mifareUltralight readMultiplePages AsyncCallback data: " + data); 2026 } 2027 }); 2028} catch (busiError) { 2029 console.error("mifareUltralight readMultiplePages AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 2030 "message: ${(busiError as Businsess).message}"); 2031} 2032``` 2033 2034### MifareUltralightTag.writeSinglePage<sup>9+</sup> 2035 2036writeSinglePage(pageIndex: number, data: number[]): Promise\<void> 2037 2038写入一页数据,数据大小为4字节。使用Promise方式作为异步方法。 2039 2040**需要权限:** ohos.permission.NFC_TAG 2041 2042**系统能力:** SystemCapability.Communication.NFC.Tag 2043 2044**参数:** 2045 2046| 参数名 | 类型 | 必填 | 说明 | 2047| -------- | ----------------------- | ---- | -------------------------------------- | 2048| pageIndex | number | 是 | 要写入页面的索引,从0开始。 | 2049| data | number[] | 是 | 要写入页面的数据内容,必须是4个字节大小。 | 2050 2051**错误码:** 2052 2053以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 2054 2055| 错误码ID | 错误信息| 2056| ------- | -------| 2057| 3100201 | Tag running state is abnormal in service. | 2058 2059**示例:** 2060 2061```js 2062import tag from '@ohos.nfc.tag'; 2063import {BusinessError} from '@ohos.base'; 2064 2065// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareUltralight' correctly. 2066 2067// connect the tag at first if not connected. 2068if (!mifareUltralight.isTagConnected()) { 2069 if (!mifareUltralight.connectTag()) { 2070 console.log("mifareUltralight connectTag failed."); 2071 return; 2072 } 2073} 2074 2075try { 2076 let pageIndex = 1; // change it to be correct index. 2077 let rawData = [0x01, 0x02, 0x03, 0x04]; // MUST be 4 bytes, change it to be correct raw data. 2078 mifareUltralight.writeSinglePage(pageIndex, rawData).then(() => { 2079 console.log("mifareUltralight writeSinglePage Promise success."); 2080 }).catch((err : BusinessError)=> { 2081 console.error("mifareUltralight writeSinglePage Promise err Code: ${err.code}, message: ${err.message}"); 2082 }); 2083} catch (busiError) { 2084 console.error("mifareUltralight writeSinglePage Promise catch Code: ${(busiError as Businsess).code}, " + 2085 "message: ${(busiError as Businsess).message}"); 2086} 2087``` 2088 2089### MifareUltralightTag.writeSinglePage<sup>9+</sup> 2090 2091writeSinglePage(pageIndex: number, data: number[], callback: AsyncCallback\<void>): void 2092 2093写入一页数据,数据大小为4字节。使用AsyncCallback方式作为异步方法。 2094 2095**需要权限:** ohos.permission.NFC_TAG 2096 2097**系统能力:** SystemCapability.Communication.NFC.Tag 2098 2099**参数:** 2100 2101| 参数名 | 类型 | 必填 | 说明 | 2102| -------- | ----------------------- | ---- | ------------------------ | 2103| pageIndex | number | 是 | 要写入页面的索引,从0开始。 | 2104| data | number[] | 是 | 要写入页面的数据内容,必须是4个字节大小。 | 2105| callback|AsyncCallback\<void> |是| 以callback形式异步返回页操作结果。 | 2106 2107**错误码:** 2108 2109以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 2110 2111| 错误码ID | 错误信息| 2112| ------- | -------| 2113| 3100201 | Tag running state is abnormal in service. | 2114 2115**示例:** 2116 2117```js 2118import tag from '@ohos.nfc.tag'; 2119import {BusinessError} from '@ohos.base'; 2120 2121// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareUltralight' correctly. 2122 2123// connect the tag at first if not connected. 2124if (!mifareUltralight.isTagConnected()) { 2125 if (!mifareUltralight.connectTag()) { 2126 console.log("mifareUltralight connectTag failed."); 2127 return; 2128 } 2129} 2130 2131try { 2132 let pageIndex = 1; // change it to be correct index. 2133 let rawData = [0x01, 0x02, 0x03, 0x04]; // MUST be 4 bytes, change it to be correct raw data. 2134 mifareUltralight.writeSinglePage(pageIndex, rawData, (err : BusinessError)=> { 2135 if (err) { 2136 console.error("mifareUltralight writeSinglePage AsyncCallback Code: ${err.code}, message: ${err.message}"); 2137 } else { 2138 console.log("mifareUltralight writeSinglePage AsyncCallback success."); 2139 } 2140 }); 2141} catch (busiError) { 2142 console.error("mifareUltralight writeSinglePage AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 2143 "message: ${(busiError as Businsess).message}"); 2144} 2145``` 2146 2147### MifareUltralightTag.getType<sup>9+</sup> 2148 2149getType(): [tag.MifareUltralightType](js-apis-nfcTag.md#mifareultralighttype9) 2150 2151获取MIFARE Ultralight标签的类型。 2152 2153**系统能力:** SystemCapability.Communication.NFC.Tag 2154 2155**返回值:** 2156 2157| **类型** | **说明** | 2158| ------------------ | --------------------------| 2159| [tag.MifareUltralightType](js-apis-nfcTag.md#mifareultralighttype9) | MIFARE Ultralight标签的类型。| 2160 2161**示例:** 2162 2163```js 2164import tag from '@ohos.nfc.tag'; 2165 2166// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'mifareUltralight' correctly. 2167let getType : tag.MifareUltralightType = mifareClassic.getType(); 2168console.log("mifareUltralight getType: " + getType); 2169``` 2170 2171## NdefFormatableTag<sup>9+</sup> 2172 2173NdefFormatableTag为NDEF Formattable的标签提供格式化操作,继承自TagSession。 2174 2175TagSession是所有NFC Tag 技术类型的基类, 提供建立连接和发送数据等共同接口。具体请参见[TagSession](js-apis-tagSession.md)。 2176 2177以下是NdefFormatableTag的独有接口。 2178 2179### NdefFormatableTag.format<sup>9+</sup> 2180 2181format(message: [NdefMessage](#ndefmessage9)): Promise\<void> 2182 2183将标签格式化为NDEF标签,将NDEF消息写入NDEF标签。使用Promise方式作为异步方法。 2184 2185**需要权限:** ohos.permission.NFC_TAG 2186 2187**系统能力:** SystemCapability.Communication.NFC.Tag 2188 2189**参数:** 2190 2191| 参数名 | 类型 | 必填 | 说明 | 2192| -------- | ----------------------- | ---- | -------------------------------------- | 2193| message | [NdefMessage](#ndefmessage9) | 是 | 格式化成功时要写入的NDEF消息。可以为null,为null时仅格式化标签,不写入内容。 | 2194 2195**错误码:** 2196 2197以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 2198 2199| 错误码ID | 错误信息| 2200| ------- | -------| 2201| 3100201 | Tag running state is abnormal in service. | 2202 2203**示例:** 2204 2205```js 2206import tag from '@ohos.nfc.tag'; 2207import {BusinessError} from '@ohos.base'; 2208 2209// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefFormatable' correctly. 2210 2211// connect the tag at first if not connected. 2212if (!ndefFormatable.isTagConnected()) { 2213 if (!ndefFormatable.connectTag()) { 2214 console.log("ndefFormatable connectTag failed."); 2215 return; 2216 } 2217} 2218 2219try { 2220 // ndefMessage created from raw data, such as: 2221 let ndefMessage = tag.ndef.createNdefMessage([0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]); // MUST can be parsed as NDEF Record. 2222 // or ndefMessage created from tag.ndef.createNdefMessage(ndefRecords: NdefRecord[]) 2223 2224 ndefFormatable.format(ndefMessage).then(() => { 2225 console.log("ndefFormatable format Promise success."); 2226 }).catch((err : BusinessError)=> { 2227 console.error("ndefFormatable format Promise err Code: ${err.code}, message: ${err.message}"); 2228 }); 2229} catch (busiError) { 2230 console.error("ndefFormatable format Promise catch busiError Code: ${(busiError as Businsess).code}, " + 2231 "message: ${(busiError as Businsess).message}"); 2232} 2233``` 2234 2235### NdefFormatableTag.format<sup>9+</sup> 2236 2237format(message: [NdefMessage](#ndefmessage9), callback: AsyncCallback\<void>): void 2238 2239将标签格式化为NDEF标签,然后将NDEF消息写入NDEF标签。使用AsyncCallback方式作为异步方法。 2240 2241**需要权限:** ohos.permission.NFC_TAG 2242 2243**系统能力:** SystemCapability.Communication.NFC.Tag 2244 2245**参数:** 2246 2247| 参数名 | 类型 | 必填 | 说明 | 2248| -------- | ----------------------- | ---- | -------------------------------------- | 2249| message | [NdefMessage](#ndefmessage9) | 是 | 格式化成功时要写入的Ndef消息。可以为null,为null时仅格式化标签,不写入内容。 | 2250 2251**返回值:** 2252 2253| **类型** | **说明** | 2254| ------------------ | --------------------------| 2255| callback: AsyncCallback\<void> | 以callback形式异步返回格式化操作结果。 | 2256 2257**错误码:** 2258 2259以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 2260 2261| 错误码ID | 错误信息| 2262| ------- | -------| 2263| 3100201 | Tag running state is abnormal in service. | 2264 2265**示例:** 2266 2267```js 2268import tag from '@ohos.nfc.tag'; 2269import {BusinessError} from '@ohos.base'; 2270 2271// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefFormatable' correctly. 2272 2273// connect the tag at first if not connected. 2274if (!ndefFormatable.isTagConnected()) { 2275 if (!ndefFormatable.connectTag()) { 2276 console.log("ndefFormatable connectTag failed."); 2277 return; 2278 } 2279} 2280 2281try { 2282 // ndefMessage created from raw data, such as: 2283 let ndefMessage = tag.ndef.createNdefMessage([0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]); // MUST can be parsed as NDEF Record. 2284 // or ndefMessage created from tag.ndef.createNdefMessage(ndefRecords: NdefRecord[]) 2285 2286 ndefFormatable.format(ndefMessage, (err : BusinessError)=> { 2287 if (err) { 2288 console.log("ndefFormatable format AsyncCallback Code: ${err.code}, message: ${err.message}"); 2289 } else { 2290 console.log("ndefFormatable format AsyncCallback success."); 2291 } 2292 }); 2293} catch (busiError) { 2294 console.log("ndefFormatable format AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 2295 "message: ${(busiError as Businsess).message}"); 2296} 2297``` 2298 2299### NdefFormatableTag.formatReadOnly<sup>9+</sup> 2300 2301formatReadOnly(message: [NdefMessage](#ndefmessage9)): Promise\<void> 2302 2303将标签格式化为NDEF标签,将NDEF消息写入NDEF标签,之后将标签设置为只读。使用Promise方式作为异步方法。 2304 2305**需要权限:** ohos.permission.NFC_TAG 2306 2307**系统能力:** SystemCapability.Communication.NFC.Tag 2308 2309**参数:** 2310 2311| 参数名 | 类型 | 必填 | 说明 | 2312| -------- | ----------------------- | ---- | -------------------------------------- | 2313| message | [NdefMessage](#ndefmessage9) | 是 | 格式化成功时要写入的NDEF消息。可以为null,为null时仅格式化标签,不写入内容。 | 2314 2315**错误码:** 2316 2317以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 2318 2319| 错误码ID | 错误信息| 2320| ------- | -------| 2321| 3100201 | Tag running state is abnormal in service. | 2322 2323**示例:** 2324 2325```js 2326import tag from '@ohos.nfc.tag'; 2327import {BusinessError} from '@ohos.base'; 2328 2329// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefFormatable' correctly. 2330 2331// connect the tag at first if not connected. 2332if (!ndefFormatable.isTagConnected()) { 2333 if (!ndefFormatable.connectTag()) { 2334 console.log("ndefFormatable connectTag failed."); 2335 return; 2336 } 2337} 2338 2339try { 2340 // ndefMessage created from raw data, such as: 2341 let ndefMessage = tag.ndef.createNdefMessage([0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]); // MUST can be parsed as NDEF Record. 2342 // or ndefMessage created from tag.ndef.createNdefMessage(ndefRecords: NdefRecord[]) 2343 2344 ndefFormatable.formatReadOnly(ndefMessage).then(() => { 2345 console.log("ndefFormatable formatReadOnly Promise success."); 2346 }).catch((err : BusinessError)=> { 2347 console.log("ndefFormatable formatReadOnly Promise Code: ${err.code}, message: ${err.message}"); 2348 }); 2349} catch (busiError) { 2350 console.error("ndefFormatable formatReadOnly Promise catch Code: ${(busiError as Businsess).code}, " + 2351 "message: ${(busiError as Businsess).message}"); 2352} 2353``` 2354 2355### NdefFormatableTag.formatReadOnly<sup>9+</sup> 2356 2357formatReadOnly(message: [NdefMessage](#ndefmessage9), callback: AsyncCallback\<void>): void 2358 2359将标签格式化为NDEF标签,然后将NDEF消息写入NDEF标签,之后将标签设置为只读。使用callback方式作为异步方法。 2360 2361**需要权限:** ohos.permission.NFC_TAG 2362 2363**系统能力:** SystemCapability.Communication.NFC.Tag 2364 2365**参数:** 2366 2367| 参数名 | 类型 | 必填 | 说明 | 2368| -------- | ----------------------- | ---- | -------------------------------------- | 2369| message | [NdefMessage](#ndefmessage9) | 是 | 格式化成功时要写入的NDEF消息。可以为null,为null时仅格式化标签,不写入内容。| 2370 2371**返回值:** 2372 2373| **类型** | **说明** | 2374| ------------------ | --------------------------| 2375| callback: AsyncCallback\<void> | 以callback形式异步返回格式化操作结果。 | 2376 2377**错误码:** 2378 2379以下错误码的详细介绍请参见[NFC错误码](errorcode-nfc.md)。 2380 2381| 错误码ID | 错误信息| 2382| ------- | -------| 2383| 3100201 | Tag running state is abnormal in service. | 2384 2385**示例:** 2386 2387```js 2388import tag from '@ohos.nfc.tag'; 2389import {BusinessError} from '@ohos.base'; 2390 2391// see 'tag.TagInfo' at 'js-apis-nfcTag.md', obtains the 'ndefFormatable' correctly. 2392 2393// connect the tag at first if not connected. 2394if (!ndefFormatable.isTagConnected()) { 2395 if (!ndefFormatable.connectTag()) { 2396 console.log("ndefFormatable connectTag failed."); 2397 return; 2398 } 2399} 2400 2401try { 2402 // ndefMessage created from raw data, such as: 2403 let ndefMessage = tag.ndef.createNdefMessage([0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]); // MUST can be parsed as NDEF Record. 2404 // or ndefMessage created from tag.ndef.createNdefMessage(ndefRecords: NdefRecord[]) 2405 2406 ndefFormatable.formatReadOnly(ndefMessage, (err : BusinessError)=> { 2407 if (err) { 2408 console.error("ndefFormatable formatReadOnly AsyncCallback err Code: ${err.code}, message: ${err.message}"); 2409 } else { 2410 console.log("ndefFormatable formatReadOnly AsyncCallback success."); 2411 } 2412 }); 2413} catch (busiError) { 2414 console.error("ndefFormatable formatReadOnly AsyncCallback catch Code: ${(busiError as Businsess).code}, " + 2415 "message: ${(busiError as Businsess).message}"); 2416} 2417``` 2418