See NFC 读取器“SELECT(通过 AID)”APDU 未路由到 Android 设备 https://stackoverflow.com/q/50316799/2425802关于调试和最终结果。 TL;DR 读者可能已经不复存在了。
我的 Android 设备已连接 ACR122U 读卡器。我的最终目标是在 HCE 模式下使用另一台 Android 设备来实现设备之间的数据通信。
目前我在与 ACR122U 读卡器集成时遇到问题。我使用供应商提供的 lib acssmc-1.1.1.jar 提供程序。这是我目前拥有的代码(省略了打开阅读器的示例代码)。
mReader.power(slotNum, Reader.CARD_WARM_RESET);
mReader.setProtocol(slotNum, Reader.PROTOCOL_T0 | Reader.PROTOCOL_T1);
//FF 00 00 00 04 D4 4A 01 00 00 - Polling for the ISO14443-4 A ??
byte[] w = new byte[255];
int len = mReader.transmit(0, new byte[] { (byte)0xFF, 0x00, 0x00, 0x00, 0x04,(byte)0xD4, 0x4A, 0x01, 0x00}, 9, w, w.length);
Log.e("Response", "r: " + NfcUtils.convertBinToASCII(w, 0, len));
//00 A4 04 00 07 F0 01 02 03 04 05 07 00 - Select AID APDU
w = new byte[255];
mReader.transmit(0, new byte[] {0x00, (byte) 0xA4, 0x04, 0x00, 7,
(byte)0xF0, 0x01, 0x02, 0x03, 0x04, (byte) 0x05, 0x07, 0}, 13, w, w.length);
Log.e("Response", "r: " + Arrays.toString (recvBuffer));
如果我将标签轻触 NFC 读取器,这就是我得到的输出
r: D54B0101440004048853606A9000
r: lots of zeroes
当我点击 Android 设备时,这是响应:
r: D54B6300
r: lots of zeroes
基本上它在轮询阶段失败了(?)。在 Android 设备上我有一个基本的HostAdpuService
执行:
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.");
}
}
processCommandApdu
从来没有被叫过。当我点击设备时,查看 Android 设备的日志,目前找不到任何相关内容。
我在网上浏览了几个示例,但无法使其在其他(非 Android)平台(Windows、OSX)上运行。