5

Mifare1Kタグのセクター0の最初のブロックに単純な「HelloWorld」文字列を書き込もうとしています。タグは新しいもので、デフォルトの構成になっています。セクタートレーラー(ブロック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)
4

2 に答える 2

8

ブロック 0 に書き込もうとしていますが、これは不可能です。ブロック 0 は常に読み取り専用であり、アクセス条件で書き込み可能とされていてもです。ブロック 0 には、UID とその他の製造元データが含まれています。代わりにブロック 1 または 2 に書き込んでみて、まだ同じ問題があるかどうかを確認してください。

于 2012-07-09T07:22:16.693 に答える
1

リーダーに接続されていないタグから読み取ろうとすると、その特定の例外が発生しました。

一部のカード/リーダーの組み合わせでは、まともな接続を維持するのが難しいことを知っています.

たとえば、私の Nexus S では一部のタグとの接続を維持するのに問題があります。Nexus S には最強のフィールドはありません。その点ではGalaxy Noteも似ていると思います。

他のブランドのタグや他のリーダーを試してみてください。

また、for ループを介して読み取りを実行して、接続が維持されているかどうかを確認します。

于 2012-07-09T00:53:40.180 に答える