ACR122ドライバーがインストールされたWindowsマシンにACR122U NFCリーダー/ライターを接続しています。
API を使用javax.smartcardio
して SELECT (AID による) ADPU を Android デバイス (HCE モードにする必要があります) に送信しようとしています。
これは私のコードです:
TerminalFactory factory = TerminalFactory.getDefault();
List<CardTerminal> terminals = factory.terminals().list();
CardTerminal terminal = terminals.get(0);
System.out.println(terminal.getName());
Card card = terminal.connect("*");
CardChannel channel = card.getBasicChannel();
execute(channel, new byte[] { (byte) 0xFF, 0x00, 0x51, (byte) 195, 0x00}, card);
execute(channel, new byte[] { (byte)0xFF, 0x00, 0x00, 0x00, 0x04,(byte)0xD4, 0x4A, 0x01, 0x00}, card); //InListPassiveTarget
execute(channel, new byte[] { (byte)0xFF, 0x00, 0x00, 0x00, 0x04,(byte)0xD4, 0x4A, 0x01, 0x00}, card); //InListPassiveTarget
execute(channel, new byte[] {0x00, (byte) 0xA4, 0x04, 0x00, 7,
(byte)0xF0, 0x01, 0x02, 0x03, 0x04, (byte) 0x05, 0x07, 0}, card); //select AID
...
public static void execute(CardChannel channel, byte[] command, Card...cards) throws CardException {
ByteBuffer r = ByteBuffer.allocate(1024);
channel.transmit(bufferFromArray(command), r);
System.out.println(convertBinToASCII(r.array(), 0, r.position()));
}
これは私が得る出力です:
ACS ACR122 0 3B8F8001804F0CA000000306030000000000006B C3 D54B6300 D54B010108032004010203049000
私01020304
のAndroidデバイスからNFCリーダーに提示されたUIDだと思います。SELECT APDU は応答を返しません。長さは 0 バイトです。
私の Android デバイスには、次のサービスがあります。
public class MyHostApduService extends HostApduService {
@Override
public void onCreate() {
super.onCreate();
Log.e("APDU", "APDU service was created.");
}
@Override
public byte[] processCommandApdu(byte[] apdu, Bundle extras) {
Log.e("APDU", "command apdu: " + Arrays.toString(apdu));
return new byte[2];
}
@Override
public void onDeactivated(int reason) {
Log.e("APDU", "ON DEACTIVATED.");
}
}
しかしprocessCommandAdpu
、呼び出されていません。ログを調べたところ、SELECT ADPU がリーダーに送信されたと思われるときに何も見つけることができなかったので、ADPU が Android デバイスに到達していないようです。
これは、Android プロジェクトの apduservice.xml です。
<host-apdu-service xmlns:android="http://schemas.android.com/apk/res/android"
android:description="@string/servicedesc"
android:requireDeviceUnlock="false" >
<aid-group
android:category="other"
android:description="@string/aiddescription" >
<aid-filter android:name="F0010203040507" />
</aid-group>
</host-apdu-service>
それに加えて、送信時に NFC リーダーが多少動かなくなる ADPU がいくつかあります。例えば、
execute(channel, new byte[] {(byte) 0xFF, 0x00, 0x00, 0x00, 0x02, (byte) 0xd4, 0x04}, card);
これは、PN532 チップの現在のステータスを照会する疑似 APDU であり、応答を返しません。この特定のリーダーに欠陥がある可能性はありますか? どうすれば確認できますか?
更新(チャットでの議論に基づく):
2 番目のリーダー (同じモデル、同じバージョン) を使用したテストが機能しました。したがって、最初のリーダーのあいまいな設定であるか、リーダーが誤動作していた可能性があります。
両方のリーダーのバージョン情報は同じです。
- ACR122U ファームウェア バージョン: 41435231323255323135 (-> ACR122U215)
- PN532 バージョン: D503 32010607 9000 (-> PN532 v1.6)