使用Android NFC写入Mifare标签?

5
我正在尝试将一个简单的“Hello World”字符串写入Mifare 1K标签的第0扇区的第一块。该标签是全新的,具有默认配置。当读取扇区尾(块3)时,其内容为:00 00 00 00 00 00 00 00 ff 07 80 69 ff ff ff ff ff ff ff ff。因此,访问条件为ff 07 80 69,这意味着我可以使用A密钥读写每个块。
然而,我无法在标签上写入任何内容。以下是我的代码:
try {
    mfc.connect();
    boolean auth = false;

    auth = mfc.authenticateSectorWithKeyA(0,MifareClassic.KEY_DEFAULT);

    if (auth) {

        String text = "Hello, World!";
        byte[] value  = text.getBytes();
        byte[] toWrite = new byte[MifareClassic.BLOCK_SIZE];        

        for (int i=0; i<MifareClassic.BLOCK_SIZE; i++) {
              if (i < value.length) toWrite[i] = value[i];
              else toWrite[i] = 0;
        }           

        mfc.writeBlock(0, toWrite);
   }    

我遇到了下面的异常:Transceived failed

我做错了什么?

这里是堆栈跟踪:

07-09 00:19:44.836: W/System.err(13167):    at android.nfc.TransceiveResult.getResponseOrThrow(TransceiveResult.java:52)
07-09 00:19:44.843: W/System.err(13167):    at android.nfc.tech.BasicTagTechnology.transceive(BasicTagTechnology.java:151)
07-09 00:19:44.843: W/System.err(13167):    at android.nfc.tech.MifareClassic.writeBlock(MifareClassic.java:453)
07-09 00:19:44.843: W/System.err(13167):    at com.example.andorid.apis.mifare.MainActivity.resolveIntent(MainActivity.java:128)
07-09 00:19:44.843: W/System.err(13167):    at com.example.andorid.apis.mifare.MainActivity.onNewIntent(MainActivity.java:275)
07-09 00:19:44.843: W/System.err(13167):    at android.app.Instrumentation.callActivityOnNewIntent(Instrumentation.java:1123)
07-09 00:19:44.843: W/System.err(13167):    at android.app.ActivityThread.deliverNewIntents(ActivityThread.java:2041)
07-09 00:19:44.843: W/System.err(13167):    at android.app.ActivityThread.performNewIntents(ActivityThread.java:2054)
07-09 00:19:44.843: W/System.err(13167):    at android.app.ActivityThread.handleNewIntent(ActivityThread.java:2063)
07-09 00:19:44.843: W/System.err(13167):    at android.app.ActivityThread.access$1400(ActivityThread.java:122)
07-09 00:19:44.843: W/System.err(13167):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1193)
07-09 00:19:44.851: W/System.err(13167):    at android.os.Handler.dispatchMessage(Handler.java:99)
07-09 00:19:44.851: W/System.err(13167):    at android.os.Looper.loop(Looper.java:137)
07-09 00:19:44.851: W/System.err(13167):    at android.app.ActivityThread.main(ActivityThread.java:4340)
07-09 00:19:44.851: W/System.err(13167):    at java.lang.reflect.Method.invokeNative(Native Method)
07-09 00:19:44.851: W/System.err(13167):    at java.lang.reflect.Method.invoke(Method.java:511)
07-09 00:19:44.851: W/System.err(13167):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
07-09 00:19:44.851: W/System.err(13167):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
07-09 00:19:44.851: W/System.err(13167):    at dalvik.system.NativeStart.main(Native Method)

你能展示整个堆栈跟踪吗? - Brad
我遇到了同样的错误,传输失败。我认为这是Android ICS4.0.3和ICS 4.0.4的一个问题。 我在S3 i9300和Galaxy Note E160K上进行了测试,都失败了。我的MiFare 1k卡可以通过其他应用程序读写NDEF。 - fordiy
2个回答

8

您正在尝试写入块0,但这是不可能的。块0始终为只读,即使访问条件表明它是可写的。块0包含UID和一些其他制造商数据。请尝试写入块1或2,看看是否仍然有同样的问题。


1

我曾经遇到过这种特殊的异常情况,当尝试读取一个未连接到读卡器的标签时会出现。

我知道对于某些卡片/读卡器组合来说,保持良好的连接是很困难的。

例如,我的 Nexus S 在与某些标签保持连接方面存在问题。Nexus S 的电磁场不是最强的。我认为 Galaxy Note 在这方面也是类似的。

尝试一些其他品牌的标签以及其他读卡器。

此外,我建议通过 for 循环运行您的读取操作,以查看它是否能够保持连接,如果这有意义的话。


不...我不认为这是问题所在。我可以轻松地使用NXP标签编写器编写数据。我有一个Galaxy Nexus i9250。 - Michael Eilers Smith

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接