【问题标题】:NFC on Nexus S: "TagLostException" when writing to unknown block on ISO 15693 ChipNexus S 上的 NFC:写入 ISO 15693 芯片上的未知块时出现“TagLostException”
【发布时间】:2011-07-21 08:59:00
【问题描述】:

我想知道是否有人偶然发现了我遇到的问题。

我正在编写一个应用程序,以使用 Nexus S NFC 功能与特定的 ISO 15693 RFID 芯片通信。大多数情况下,手机和芯片之间的通信工作正常。 读取和写入块也可以使用transcieve() 发送原始字节数组。

我的芯片有 8 个块,每个 4 字节大。 当我尝试写入 0 - 7 以外的块时,Android 会抛出 TagLostException:

07-21 14:07:39.390: WARN/System.err(5770): android.nfc.TagLostException: Tag was lost.
07-21 14:07:39.394: WARN/System.err(5770):     at android.nfc.tech.BasicTagTechnology.transceive(BasicTagTechnology.java:141)
07-21 14:07:39.398: WARN/System.err(5770):     at android.nfc.tech.NfcV.transceive(NfcV.java:92)
07-21 14:07:39.398: WARN/System.err(5770):     at de.myapp.ForegroundDispatchNfcV.sendRawCommand(ForegroundDispatchNfcV.java:246)
07-21 14:07:39.402: WARN/System.err(5770):     at de.myapp.ForegroundDispatchNfcV$3.onClick(ForegroundDispatchNfcV.java:135)
07-21 14:07:39.406: WARN/System.err(5770):     at android.view.View.performClick(View.java:2485)
07-21 14:07:39.406: WARN/System.err(5770):     at android.view.View$PerformClick.run(View.java:9080)
07-21 14:07:39.410: WARN/System.err(5770):     at android.os.Handler.handleCallback(Handler.java:587)
07-21 14:07:39.414: WARN/System.err(5770):     at android.os.Handler.dispatchMessage(Handler.java:92)
07-21 14:07:39.414: WARN/System.err(5770):     at android.os.Looper.loop(Looper.java:123)
07-21 14:07:39.417: WARN/System.err(5770):     at android.app.ActivityThread.main(ActivityThread.java:3683)
07-21 14:07:39.421: WARN/System.err(5770):     at java.lang.reflect.Method.invokeNative(Native Method)
07-21 14:07:39.421: WARN/System.err(5770):     at java.lang.reflect.Method.invoke(Method.java:507)
07-21 14:07:39.425: WARN/System.err(5770):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
07-21 14:07:39.429: WARN/System.err(5770):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
07-21 14:07:39.429: WARN/System.err(5770):     at dalvik.system.NativeStart.main(Native Method)

我对阅读 ISO 15693 标准的期望是取回 2 个字节,其中包含有关发生的错误的信息,但它看起来好像芯片会保持安静并且不发送任何答案。 尝试读取无效块时也会出现同样的问题。

这是我的卡的问题还是 API / NFC 的问题? 有人知道这个问题吗?

【问题讨论】:

    标签: android nfc rfid iso-15693


    【解决方案1】:

    NFC 芯片有一个内部状态机,用于跟踪它检测到的标签。当标签超出阅读器/手机的范围并且您尝试对其进行写入时,您将收到此异常。

    【讨论】:

    • 感谢您的回答。这实际上不是我的问题。芯片留在现场。从现场移除 RFID 芯片时,我收到一条不同的消息(标签丢失,重新启动轮询循环)。另外,当我捕捉到上面显示的异常时,我可以毫无问题地读取和写入所有有效块!
    • 如果卡返回不成功状态代码 (9000) 我假设 android 的 NFC 堆栈假定它是一个异常,因此抛出一个异常。如果您仍然可以在异常后写入标签,只需让您的例程处理异常作为可能的响应的一部分......如果问题是您的标签,您可以制作一个使用 USB NFC 阅读器的小程序来编写相同的命令看看你得到什么回应。你可以在网上买到便宜的 USB NFC 读卡器(用的是 ACR122U)
    【解决方案2】:

    当卡向 Nexus S 发回不正确的 CRC 时,我遇到了这个问题。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多