我想知道是否有人遇到了我遇到的问题。
我正在编写一个应用程序,使用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中的问题? 有没有人更多地了解这个问题?
答案 0 :(得分:0)
NFC芯片有一个内部状态机,可以跟踪它检测到的标签。当标签超出阅读器/手机的范围并且您尝试写入它时,您将获得此异常。
答案 1 :(得分:0)
当卡片向Nexus S发送错误的CRC时,我遇到了这个问题。