NFC на Nexus S: «TagLostException» при записи в неизвестный блок на чипе ISO 15693 - PullRequest
2 голосов
/ 21 июля 2011

Мне интересно, сталкивался ли кто-нибудь с этой проблемой, с которой я столкнулся.

Я пишу приложение для общения с конкретным RFID-чипом ISO 15693 с использованием возможностей Nexus S NFC.В большинстве случаев связь между телефоном и чипом работает нормально.Чтение и запись блоков также работает с использованием 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?Кто-нибудь знает больше об этой проблеме?

Ответы [ 2 ]

0 голосов
/ 29 июля 2011

У меня была эта проблема, когда карта отправляла неверный CRC на Nexus S.

0 голосов
/ 23 июля 2011

Чип NFC имеет внутренний конечный автомат, который отслеживает, какие теги он обнаружил. Когда тег находится вне зоны досягаемости устройства чтения / телефона и вы пытаетесь записать его, вы получите это исключение.

...