首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >具有身份验证的NTAG212 Mifare超视距

具有身份验证的NTAG212 Mifare超视距
EN

Stack Overflow用户
提问于 2014-03-28 17:25:34
回答 2查看 5.8K关注 0票数 4

我是NFC的新手,几天来,我一直在试图将NTAG212 Mifare的第7页与身份验证连接起来,我已经拥有了PWD,并准备了基于NTAG212 Docs的PWD_AUTH

我这么做..。

代码语言:javascript
运行
复制
//assume password as array of bytes
//assume pack as array of bytes
try{
nfc.connect();
byte[] cmd1 = nfc.transceive(new byte[]{ (byte) 0x30, (byte) 0x00 }); //read the page 0     to make the NFC active
nfc.transceive(new byte[]{
   (byte) 0x1B, //command for PWD_AUTH
   pass[0],
   pass[1],
   pass[2],
   pass[3]
});
byte[] cmd4 = nfc.transceive(new byte[]{ (byte) 0x30, (byte) 0x04 }); //read the page 4
}catch(TagLostException e){
  e.printStackTrace();
}catch(IOException e){
  e.printStachTrace();
}finally{
    try{
        nfc.close();
    }catch(Exception e){
      //display failed to close
    }
}

在向NFC发送android.nfc.TagLostException: Tag was lost.命令后,总是会收到PWD_AUTH错误。有人能告诉我我做错了什么吗?我的方法正确吗?请帮帮忙。

注意:我已经读了很多次NTAG212的文档,搜索过google,堆栈溢出和所有可能的资源。

蒂娅

肯斯特

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-03-28 21:07:54

发送到标记的PWD_AUTH命令没有多大意义。

PWD_AUTH命令的思想是发送您的密码(一个4字节值),如果您使用正确的密码进行身份验证,则标记将使用其密码应答,并使用其密码确认(PACK)值(一个2字节值)。然后,您可以根据预期的密码确认来验证PACK值,以“验证”标记。

所以正确的命令是:

代码语言:javascript
运行
复制
byte[] response = nfc.transceive(new byte[] {
    (byte) 0x1B, // PWD_AUTH
    pass[0], pass[1], pass[2], pass[3]
});
if ((response != null) && (response.length >= 2)) {
   byte[] pack = Arrays.copyOf(response, 2);
   // TODO: verify PACK to confirm that tag is authentic (not really,
   // but that whole PWD_AUTH/PACK authentication mechanism was not
   // really meant to bring much security, I hope; same with the
   // NTAG signature btw.)
}

您需要什么才能启用密码保护(在NTAG212上):

  1. 将PWD (第39页)设置为您想要的密码(默认值是0xFFFFFFFF)。 byte[] response =nfc.transceive(新的byte[] {(字节) 0xA2,//写(字节) 39,//页面地址传递,pass1,pass2,pass3 });
  2. 将PACK (第40页,字节0-1)设置为您想要的密码确认(默认值是0x0000)。 byte[] response =nfc.transceive(新的byte[] {(字节) 0xA2,// byte[](字节) 40,//页地址包,pack1,//字节0-1是包值(字节) 0,(字节)0 //其他字节为RFU,必须写入0 });
  3. 将AUTHLIM (第38页,字节0,位2-0)设置为失败密码验证尝试的最大次数(将此值设置为0将允许无限次数的PWD_AUTH尝试)。
  4. 将PROT (第38页,字节0,位7)设置为您想要的值(0 = PWD_AUTH (只用于写访问),1= PWD_AUTH是读写访问所必需的)。 byte[] response =nfc.transceive(新的byte[] {(字节) 0x30,// read (字节) 38 //页地址});if ((响应= null) & (response.length >= 16)) { // read总是返回4页布尔prot = false;// false = PWD_AUTH表示只写,true = PWD_AUTH表示读和写int authlim = 0;// byte[] {(字节) 0xA2,//写(字节) 38,//页地址(字节)((响应& 0x078) x (prot ? 0x080 : 0x000) ) (response1 &0x007),response1,response2,response3 //保存字节1-3的旧值,您也可以简单地将它们设置为0,因为它们当前是RFU,并且必须始终写为0(response1、response2、response3也将包含0,因为它们包含read值) });}
  5. 将AUTH0 (第37页,字节3)设置为需要密码身份验证的第一页。 byte[] response =nfc.transceive(新的byte[] {(字节) 0x30,// read (字节) 37 //页地址});if ((响应!= null) & (response.length >= 16)) { // read总是返回4页布尔prot = false;// false = PWD_AUTH表示只写,true = PWD_AUTH表示读和写int auth0 = 0;// NTAG212 response =nfc.transceive(新的byte[] {(字节) 0xA2,//写(字节) 37,//页地址响应,//保持字节0 response1的旧值,//保持字节1 response2的旧值,//保持字节2(字节)的旧值(auth0 & 0x0ff) });}

如果使用MifareUltralight标记技术,而不是直接使用transceive方法,还可以使用readPageswritePage方法:

  • 读取命令 byte[] response =nfc.transceive(新的byte[] {(字节) 0x30,// READ (字节) (pageAddress & 0x0ff) //页面地址}); 等于 byte[]反应= nfc.readPages(pageAddress);
  • 写命令 byte[]数据={(字节).(字节).};byte[] response =nfc.transceive(新的byte[] {(字节) 0xA2,//写(字节) (pageAddress & 0x0ff),//页地址数据,data1,data2,data3 }); 等于 nfc.writePage(pageAddress,data);
票数 10
EN

Stack Overflow用户

发布于 2021-07-20 12:15:04

当在TagLostException操作期间发送错误的密码时,一个将获得PWD_AUTH

确保在PWD_AUTH操作中发送的4字节密码与使用常规WRITE操作设置标记的PWD字段的内容相匹配。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22719465

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档