操作及管理NFC Tag

2024-01-23 16:52 更新

本模块主要用于操作及管理NFC Tag。

说明

本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

声明技术

开发Tag读写相关应用时,需要在应用的属性配置文件中,声明与NFC相关的属性值,比如,在module.json5文件中,声明下面属性值:

  1. {
  2. "module": {
  3. // other declared attributes.
  4. "abilities": [
  5. {
  6. "skills": [
  7. {
  8. "actions": [
  9. // other declared actions,
  10. // add the nfc tag action
  11. "ohos.nfc.tag.action.TAG_FOUND"
  12. ]
  13. }
  14. ],
  15. "metadata": [
  16. {
  17. "name": "tag-tech",
  18. "value": "NfcA"
  19. },
  20. {
  21. "name": "tag-tech",
  22. "value": "IsoDep"
  23. },
  24. // add other technology if neccessary,
  25. // such as: NfcB/NfcF/NfcV/Ndef/MifareClassic/MifareUL/NdefFormatable
  26. ]
  27. }
  28. ],
  29. "requestPermissions": [
  30. "name": "ohos.permission.NFC_TAG",
  31. "reason": "tag",
  32. ]
  33. }
  34. }
注意
  1. 声明"actions"字段的内容填写,必须是"ohos.nfc.tag.action.TAG_FOUND",不能更改。
  2. 声明技术时"metadata"中的"name"字段的内容填写,必须是"tag-tech",不能更改。
  3. 声明技术时"metadata"中的"value"字段的内容填写,必须是"NfcA/NfcB/NfcF/NfcV/IsoDep/Ndef/MifareClassic/MifareUL/NdefFormatable"中的一个或多个。填写错误会造成解析失败。
  4. 声明权限时"requestPermissions"中的"name"字段的内容填写,必须是"ohos.permission.NFC_TAG",不能更改。

导入模块

  1. import tag from '@ohos.nfc.tag';

tag.TagInfo

在对相关Tag类型卡片进行读写之前,必须先获取TagInfo相关属性值,以确认设备读取到的Tag卡片支持哪些技术类型。这样Tag应用程序才能调用正确的接口和所读取到的Tag卡片进行通信。

  1. import tag from '@ohos.nfc.tag';
  2. onCreate(want, launchParam) {
  3. // add other code here...
  4. // want is initialized by nfc service, contains tag info for this found tag
  5. var tagInfo;
  6. try {
  7. tagInfo = tag.getTagInfo(want);
  8. } catch (error) {
  9. console.log("tag.getTagInfo catched error: " + error);
  10. }
  11. if (tagInfo == null || tagInfo == undefined) {
  12. console.log("no TagInfo to be created, ignore it.");
  13. return;
  14. }
  15. // get the supported technologies for this found tag.
  16. var isNfcATag = false;
  17. var isIsoDepTag = false;
  18. for (var i = 0; i < tagInfo.technology.length; i++) {
  19. if (tagInfo.technology[i] == tag.NFC_A) {
  20. isNfcATag = true;
  21. }
  22. if (tagInfo.technology[i] == tag.ISO_DEP) {
  23. isIsoDepTag = true;
  24. }
  25. // also check for technology: tag.NFC_B/NFC_F/NFC_V/NDEF/MIFARE_CLASSIC/MIFARE_ULTRALIGHT/NDEF_FORMATABLE
  26. }
  27. // use NfcA APIs to access the found tag.
  28. if (isNfcATag) {
  29. var nfcA;
  30. try {
  31. nfcA = tag.getNfcATag(taginfo);
  32. } catch (error) {
  33. console.log("tag.getNfcATag catched error: " + error);
  34. }
  35. // other code to read or write this found tag.
  36. }
  37. // use getIsoDep APIs to access the found tag.
  38. if (isIsoDepTag) {
  39. var isoDep;
  40. try {
  41. isoDep = tag.getIsoDep(taginfo);
  42. } catch (error) {
  43. console.log("tag.getIsoDep catched error: " + error);
  44. }
  45. // other code to read or write this found tag.
  46. }
  47. // use the same code to handle for "NfcA/NfcB/NfcF/NfcV/Ndef/MifareClassic/MifareUL/NdefFormatable".
  48. }

tag.getNfcATag

getNfcATag(tagInfo: TagInfo): NfcATag

获取NFC A类型Tag对象,通过该对象可访问NfcA技术类型的Tag。

说明

从 API version 7 开始支持,从 API version 9 开始废弃,建议使用tag.getNfcA替代。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcATag

NFC A类型Tag对象。

tag.getNfcA9+

getNfcA(tagInfo: TagInfo): NfcATag

获取NFC A类型Tag对象,通过该对象可访问NfcA技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcATag

NFC A类型Tag对象。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getNfcBTag

getNfcBTag(tagInfo: TagInfo): NfcBTag

获取NFC B类型Tag对象,通过该对象可访问NfcB技术类型的Tag。

说明

从 API version 7 开始支持,从 API version 9 开始废弃,建议使用tag.getNfcB替代。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcBTag

NFC B类型Tag对象。

tag.getNfcB9+

getNfcB(tagInfo: TagInfo): NfcBTag

获取NFC B类型Tag对象,通过该对象可访问NfcB技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcBTag

NFC B类型Tag对象。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getNfcFTag

getNfcFTag(tagInfo: TagInfo): NfcFTag

获取NFC F类型Tag对象,通过该对象可访问NfcF技术类型的Tag。

说明

从 API version 7 开始支持,从 API version 9 开始废弃,建议使用tag.getNfcF替代。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcFTag

NFC F类型Tag对象。

tag.getNfcF9+

getNfcF(tagInfo: TagInfo): NfcFTag

获取NFC F类型Tag对象,通过该对象可访问NfcF技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcFTag

NFC F类型Tag对象。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getNfcVTag

getNfcVTag(tagInfo: TagInfo): NfcVTag

获取NFC V类型Tag对象,通过该对象可访问NfcV技术类型的Tag。

说明

从 API version 7 开始支持,从 API version 9 开始废弃,建议使用tag.getNfcV替代。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcVTag

NFC V类型Tag对象。

tag.getNfcV9+

getNfcV(tagInfo: TagInfo): NfcVTag

获取NFC V类型Tag对象,通过该对象可访问NfcV技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NfcVTag

NFC V类型Tag对象。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getIsoDep9+

getIsoDep(tagInfo: TagInfo): IsoDepTag

获取IsoDep类型Tag对象,通过该对象可访问支持IsoDep技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

IsoDepTag

IsoDep类型Tag对象,通过该对象访问IsoDep类型的相关接口。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getNdef9+

getNdef(tagInfo: TagInfo): NdefTag

获取NDEF类型Tag对象,通过该对象可访问支持NDEF技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

NdefTag

NDEF类型Tag对象,通过该对象访问NDEF类型的相关接口。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getMifareClassic9+

getMifareClassic(tagInfo: TagInfo): MifareClassicTag

获取MIFARE Classic类型Tag对象,通过该对象访问支持MIFARE Classic技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

MifareClassicTag

MIFARE Classic类型Tag对象,通过该对象访问MIFARE Classic类型的相关接口。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getMifareUltralight9+

getMifareUltralight(tagInfo: TagInfo): MifareUltralightTag

获取MIFARE Ultralight类型Tag对象,通过该对象可访问支持MIFARE Ultralight技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

taginfo

TagInfo

包含Tag技术类型和相关参数,从tag.getTagInfo(want: Want)获取。

返回值:

类型

说明

MifareUltralightTag

MIFARE Ultralight类型Tag对象,通过该对象访问MIFARE Ultralight类型的相关接口。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getNdefFormatable9+

getNdefFormatable(tagInfo: TagInfo): NdefFormatableTag

获取NDEF Formatable类型Tag对象,通过该对象可访问支持NDEF Formatable技术类型的Tag。

系统能力: SystemCapability.Communication.NFC.Tag

返回值:

类型

说明

NdefFormatableTag

NDEF Formatable类型Tag对象,通过该对象访问NDEF Formatable类型的相关接口。

错误码:

以下错误码的详细介绍请参见NFC错误码

错误码ID

错误信息

3100201

Tag running state is abnormal in service.

tag.getTagInfo9+

getTagInfo(want: Want): TagInfo

从Want中获取TagInfo,Want是被NFC服务初始化,包含了TagInfo所需的属性值。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

want

Want

分发Ability时,在系统onCreate入口函数的参数中获取。

返回值:

类型

说明

TagInfo

TagInfo对象,用于获取不同技术类型的Tag对象。

tag.ndef.makeUriRecord9+

makeUriRecord(uri: string): NdefRecord;

根据输入的URI,构建NDEF标签的Record数据对象。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

uri

string

写入到NDEF Record里面的数据内容。

返回值:

类型

说明

NdefRecord

NDEF标签的Record,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。

示例:

  1. import tag from '@ohos.nfc.tag';
  2. try {
  3. let uri = "https://gitee.com/openharmony"; // change it to be correct.
  4. let ndefRecord = tag.ndef.makeUriRecord(uri);
  5. if (ndefRecord != undefined) {
  6. console.log("ndefMessage makeUriRecord rtdType: " + ndefRecord.rtdType);
  7. console.log("ndefMessage makeUriRecord payload: " + ndefRecord.payload);
  8. } else {
  9. console.log("ndefMessage makeUriRecord ndefRecord: " + ndefRecord);
  10. }
  11. } catch (busiError) {
  12. console.log("ndefMessage makeUriRecord catched busiError: " + busiError);
  13. }

tag.ndef.makeTextRecord9+

makeTextRecord(text: string, locale: string): NdefRecord;

根据输入的文本数据和编码类型,构建NDEF标签的Record。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

text

string

写入到NDEF Record里面的文本数据内容。

locale

string

文本数据内容的编码方式。

返回值:

类型

说明

NdefRecord

NDEF标签的Record,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。

示例:

  1. import tag from '@ohos.nfc.tag';
  2. try {
  3. let text = "Hello World"; // change it to be correct.
  4. let locale = "en"; // change it to be correct.
  5. let ndefRecord = tag.ndef.makeTextRecord(text, locale);
  6. if (ndefRecord != undefined) {
  7. console.log("ndefMessage makeTextRecord rtdType: " + ndefRecord.rtdType);
  8. console.log("ndefMessage makeTextRecord payload: " + ndefRecord.payload);
  9. } else {
  10. console.log("ndefMessage makeTextRecord ndefRecord: " + ndefRecord);
  11. }
  12. } catch (busiError) {
  13. console.log("ndefMessage makeTextRecord catched busiError: " + busiError);
  14. }

tag.ndef.makeMimeRecord9+

makeMimeRecord(mimeType: string, mimeData: number[]): NdefRecord;

根据输入的MIME数据和类型,构建NDEF标签的Record。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

mimeType

string

符合RFC规则的MIME类型,比如"text/plain"或"image/jpeg"。

mimeData

number[]

MIME数据内容,每个number十六进制表示,范围是0x00~0xFF。

返回值:

类型

说明

NdefRecord

NDEF标签的Record,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。

示例:

  1. import tag from '@ohos.nfc.tag';
  2. try {
  3. let mimeType = "text/plain"; // change it to be correct.
  4. let mimeData = [0x01, 0x02, 0x03, 0x04]; // change it to be correct.
  5. let ndefRecord = tag.ndef.makeMimeRecord(mimeType, mimeData);
  6. if (ndefRecord != undefined) {
  7. console.log("ndefMessage makeMimeRecord rtdType: " + ndefRecord.rtdType);
  8. console.log("ndefMessage makeMimeRecord payload: " + ndefRecord.payload);
  9. } else {
  10. console.log("ndefMessage makeMimeRecord ndefRecord: " + ndefRecord);
  11. }
  12. } catch (busiError) {
  13. console.log("ndefMessage makeMimeRecord catched busiError: " + busiError);
  14. }

tag.ndef.makeExternalRecord9+

makeExternalRecord(domainName: string, type: string, externalData: number[]): NdefRecord;

根据应用程序特定的外部数据,构建NDEF标签的Record。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

domainName

string

外部数据发布组织的域名,一般是应用程序的包名。

type

string

外部数据的指定类型。

externalData

number[]

外部数据内容,每个number十六进制表示,范围是0x00~0xFF。

返回值:

类型

说明

NdefRecord

NDEF标签的Record,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。

示例:

  1. import tag from '@ohos.nfc.tag';
  2. try {
  3. let domainName = "ohos.nfc.application"; // change it to be correct.
  4. let type = "test"; // change it to be correct.
  5. let externalData = [0x01, 0x02, 0x03, 0x04]; // change it to be correct.
  6. let ndefRecord = tag.ndef.makeExternalRecord(domainName, type, externalData);
  7. if (ndefRecord != undefined) {
  8. console.log("ndefMessage makeExternalRecord rtdType: " + ndefRecord.rtdType);
  9. console.log("ndefMessage makeExternalRecord payload: " + ndefRecord.payload);
  10. } else {
  11. console.log("ndefMessage makeExternalRecord ndefRecord: " + ndefRecord);
  12. }
  13. } catch (busiError) {
  14. console.log("ndefMessage makeExternalRecord catched busiError: " + busiError);
  15. }

tag.ndef.messageToBytes9+

messageToBytes(ndefMessage: NdefMessage): number[];

把输入的NDEF消息数据对象,转换为字节格式的数据。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

ndefMessage

NdefMessage

NDEF消息数据对象。

返回值:

类型

说明

number[]

NDEF消息数据对象,所转换成的字节格式的数据。每个number十六进制表示,范围是0x00~0xFF。

示例:

  1. import tag from '@ohos.nfc.tag';
  2. let rawData = [0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]; // MUST can be parsed as NDEF Record.
  3. let ndefMessage;
  4. try {
  5. ndefMessage = tag.ndef.createNdefMessage(rawData);
  6. console.log("ndef createNdefMessage, ndefMessage: " + ndefMessage);
  7. } catch (busiError) {
  8. console.log("ndef createNdefMessage busiError: " + busiError);
  9. }
  10. try {
  11. let rawData2 = tag.ndef.messageToBytes(ndefMessage);
  12. console.log("ndefMessage messageToBytes rawData2: " + rawData2);
  13. } catch (busiError) {
  14. console.log("ndefMessage messageToBytes catched busiError: " + busiError);
  15. }

tag.ndef.createNdefMessage9+

createNdefMessage(data: number[]): NdefMessage

使用原始字节数据创建NDEF标签的Message。该数据必须符合NDEF Record数据格式,如果不符合格式,则返回的NdeMessage数据对象,所包含的NDE Record列表会为空。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

data

number[]

原始字节,每个number十六进制表示,范围是0x00~0xFF。要求必须满足NDEF Record的格式。

返回值:

类型

说明

NdefMessage

NDEF标签的Message,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。

示例:

  1. import tag from '@ohos.nfc.tag';
  2. let rawData = [0xD1, 0x01, 0x03, 0x54, 0x4E, 0x46, 0x43]; // MUST can be parsed as NDEF Record.
  3. let ndefMessage;
  4. try {
  5. ndefMessage = tag.ndef.createNdefMessage(rawData);
  6. console.log("ndef createNdefMessage, ndefMessage: " + ndefMessage);
  7. } catch (busiError) {
  8. console.log("ndef createNdefMessage busiError: " + busiError);
  9. }

tag.ndef.createNdefMessage9+

createNdefMessage(ndefRecords: NdefRecord[]): NdefMessage

使用NDEF Records列表,创建NDEF Message。

系统能力: SystemCapability.Communication.NFC.Tag

参数:

参数名

类型

必填

说明

ndefRecords

NdefRecord[]

NDEF标签的Record列表,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。

返回值:

类型

说明

NdefMessage

NDEF标签的Message,详见NDEF技术规范《NFCForum-TS-NDEF_1.0》。

示例:

  1. import tag from '@ohos.nfc.tag';
  2. let uriRecord = tag.ndef.makeUriRecord("https://gitee.com/openharmony");
  3. let textRecord = tag.ndef.makeTextRecord("Hello World", "en");
  4. let ndefRecords = [uriRecord, textRecord];
  5. let ndefMessage;
  6. try {
  7. ndefMessage = tag.ndef.createNdefMessage(ndefRecords);
  8. console.log("ndef createNdefMessage ndefMessage: " + ndefMessage);
  9. } catch (busiError) {
  10. console.log("ndef createNdefMessage busiError: " + busiError);
  11. }

TagInfo

NFC服务在读取到标签时给出的对象,通过改对象属性,应用知道该标签支持哪些技术类型,并使用匹配的技术类型来调用相关接口。

系统能力: SystemCapability.Communication.NFC.Tag

需要权限: ohos.permission.NFC_TAG

名称

类型

可读

可写

说明

uid9+

number[]

标签的uid,每个number值是十六进制表示,范围是0x00~0xFF。

technology9+

number[]

支持的技术类型,每个number值表示所支持技术类型的常量值。

supportedProfiles

number[]

支持的技术类型,从API9开始不支持,使用tag.TagInfo#technology替代。

NdefRecord9+

NDEF标签Record属性的定义,参考NDEF标签技术规范《NFCForum-TS-NDEF_1.0》的定义细节。

系统能力: SystemCapability.Communication.NFC.Tag

名称

类型

可读

可写

说明

tnf

number

NDEF Record的TNF(Type Name Field)。

rtdType

number[]

NDEF Record的RTD(Record Type Definition)类型值,每个number十六进制表示,范围是0x00~0xFF。

id

number[]

NDEF Record的ID,每个number十六进制表示,范围是0x00~0xFF。

payload

number[]

NDEF Record的PAYLOAD,每个number十六进制表示,范围是0x00~0xFF。

技术类型定义

NFC Tag有多种不同的技术类型,定义常量描述不同的技术类型。

系统能力: SystemCapability.Communication.NFC.Tag

名称

说明

NFC_A

1

NFC-A (ISO 14443-3A)技术。

NFC_B

2

NFC-A (ISO 14443-3B)技术。

ISO_DEP

3

ISO-DEP (ISO 14443-4)技术。

NFC_F

4

NFC-F (JIS 6319-4)技术。

NFC_V

5

NFC-V (ISO 15693)技术。

NDEF

6

NDEF技术。

NDEF_FORMATABLE9+

7

可以格式化的NDEF技术。

MIFARE_CLASSIC

8

MIFARE Classic技术。

MIFARE_ULTRALIGHT

9

MIFARE Utralight技术。

TnfType9+

NDEF Record的TNF(Type Name Field)类型值,参考NDEF标签技术规范《NFCForum-TS-NDEF_1.0》的定义细节。

系统能力: SystemCapability.Communication.NFC.Tag

名称

说明

TNF_EMPTY

0x0

Empty。

TNF_WELL_KNOWN

0x1

NFC Forum well-known type [NFC RTD]。

TNF_MEDIA

0x2

Media-type as defined in RFC 2046 [RFC 2046]。

TNF_ABSOLUTE_URI

0x3

Absolute URI as defined in RFC 3986 [RFC 3986]。

TNF_EXT_APP

0x4

NFC Forum external type [NFC RTD]。

TNF_UNKNOWN

0x5

Unknown。

TNF_UNCHANGED

0x6

Unchanged (see section 2.3.3)。

NDEF Record RTD类型定义

NDEF Record的RTD(Record Type Definition)类型值,参考NDEF标签技术规范《NFCForum-TS-NDEF_1.0》的定义细节。

系统能力: SystemCapability.Communication.NFC.Tag

名称

说明

RTD_TEXT9+

[0x54]

文本类型的NDEF Record。

RTD_URI9+

[0x55]

URI类型的NDEF Record。

NfcForumType9+

NFC Forum标准里面Tag类型的定义。

系统能力: SystemCapability.Communication.NFC.Tag

名称

说明

NFC_FORUM_TYPE_1

1

NFC论坛类型1。

NFC_FORUM_TYPE_2

2

NFC论坛类型2。

NFC_FORUM_TYPE_3

3

NFC论坛类型3。

NFC_FORUM_TYPE_4

4

NFC论坛类型4。

MIFARE_CLASSIC

101

MIFARE Classic类型。

MifareClassicType9+

MIFARE Classic标签类型的定义。

系统能力: SystemCapability.Communication.NFC.Tag

名称

说明

TYPE_UNKNOWN

0

未知的MIFARE类型。

TYPE_CLASSIC

1

MIFARE Classic类型。

TYPE_PLUS

2

MIFARE Plus类型。

TYPE_PRO

3

MIFARE Pro类型。

MifareClassicSize9+

MIFARE Classic标签存储大小的定义。

系统能力: SystemCapability.Communication.NFC.Tag

名称

说明

MC_SIZE_MINI

320

每个标签5个扇区,每个扇区4个块。

MC_SIZE_1K

1024

每个标签16个扇区,每个扇区4个块。

MC_SIZE_2K

2048

每个标签32个扇区,每个扇区4个块。

MC_SIZE_4K

4096

每个标签40个扇区,每个扇区4个块。

MifareUltralightType9+

MIFARE Ultralight标签类型的定义。

系统能力: SystemCapability.Communication.NFC.Tag

名称

说明

TYPE_UNKNOWN

0

未知的 MIFARE 类型。

TYPE_ULTRALIGHT

1

MIFARE Ultralight类型。

TYPE_ULTRALIGHT_C

2

MIFARE UltralightC 类型。

以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号