NFC

iOS NFC 加密功能实现

2019-10-18  本文已影响0人  开发者1

ios NFC加密功能实现

前言:记录一下ios开发中NFC添加密码功能,卡类型为(NFCMiFareTag -->NFCMiFareUltralight),调用的iOS方法为:sendMiFareCommand。

一、JS代码实现,调用的ios原生NFC发送方法,针对卡类型为NTAG216的卡片。 NTAG212、NTAG213、NTAG215、NTAG216的配置位置不同,所以只需查到卡类型的配置起始位置即可。NTAG216的配置起始位置为E3。

二、写入密码的过程(0xA2为写入命令,0x30为读取命令)

 let pass = stringToBytes('1111'); // 密码  必须为4位  stringToBytes为字符串转byte方法;pass为数组。

 let pack = stringToBytes('11');  // 确认值 必须为2位

1、写入密码到 E5位置 ,即起始位置E3+2;

sendCommand([0xA2, E5, pass[0], pass[1], pass[2], pass[3]]);

2、将PACK(第E6页,字节0-1)设置为所需的密码确认(默认值为0x0000).

sendCommand([0xA2, E6, pack[0], pack[1], 0x00, 0x00]);

3、将AUTHLIM(第E4页,字节0,位2-0)设置为最大失败密码验证尝试次数(将此值设置为0将允许无限次数的PWD_AUTH尝试).将PROT(第E4页,字节0,位7)设置为所需的值(0 =仅在写访问时需要PWD_AUTH,1 =读和写访问需要PWD_AUTH).

let response = sendCommand([0x30,E4]); //读取E4页数据

let response = readResponseE4.result;

let prot = false; // false 为只加密写 true为读写都加密

let authlim = 0; 

let writeResponse = sendCommand([0xA2, E4, ((response[0] & 0x078) | (prot ? 0x080 : 0x000) | (authlim & 0x007)), response[1], response[2], response[3]]);

4、将AUTH0(第E3页,字节3)设置为应该要求密码验证的第一页.

let readResponseE3 = sendCommand([0x30, 0xE3]); //读取E3页数据

let writeResponseT = sendCommand([0xA2, index - 2, readResponseE3.result[0], readResponseE3.result[1], readResponseE3.result[2], (0 & 0x0ff)]); //0为密码要保护的开始位置。

三、验证密码(0x1B为验证命令)

sendCommand([0x1B, pass[0], pass[1], pass[2], pass[3]]); //验证通过会返回pack值,还需要与本地验证pack是否一致

四、删除密码

首先需要验证密码,然后只需将AUTH0(即配置起始页)设置为0x0ff即可。

let readResponse = sendCommand([0x30, E3]);

let deleteStatu = sendCommand([0xA2, E3, response[0], response[1], response[2], (0x0ff & 0x0ff)]);

五、ios原生方法

需要将传入的byte数组转成data类型

- (void)sendMiFareCommand:(NSData *)command completionHandler:(void(^)(NSData *response, NSError * _Nullable error))completionHandler API_AVAILABLE(ios(13.0)) API_UNAVAILABLE(watchos, macos, tvos);

相关参考资料

https://stackoverflow.com/questions/34390476/how-to-remove-password-protection-in-ntag216

http://www.cocoachina.com/articles/67688

上一篇下一篇

猜你喜欢

热点阅读