使用Android NFC将超过261个字节发送到Java卡
作者:互联网
我想通过NFC(类IsoDep)将长度为1699字节的APDU发送到Java卡智能卡.我得到错误
java.io.IOException: Transceive length exceeds supported maximum
我的手机是三星Galaxy S7.
我在卡上的小程序中使用了扩展长度.我已验证该卡支持扩展长度.我通过pyapdutool通过向卡发送4000字节的APDU进行了测试.
我发现编写此代码时,结果为false:
final Tag t = (Tag) tag;
myTag = IsoDep.get(t);
boolean result = myTag.isExtendedLengthApduSupported();
我的清单中有这个:
<activity
android:name=".test"
android:label="@string/title_test"
android:launchMode="singleTop"
android:theme="@style/AppTheme.NoActionBar" >
<action android:name="android.nfc.action.TAG_DISCOVERED" />
<category android:name="android.intent.category.DEFAULT" />
<intent-filter>
<action android:name="android.nfc.action.NDEF_DISCOVERED" />
</intent-filter>
</activity>
如何通过Android NFC发送1699字节(或任何大于261字节的长度)的APDU?
解决方法:
简短的回答:您不能轻易做到这一点.
您已经发现IsoDep不“支持”设备上的扩展长度APDU(即isoDep.isExtendedLengthApduSupported()返回false).实际上,这并不意味着您不能通过IsoDep对象发送扩展长度的APDU.实际上,这仅意味着IsoDep对象将不会在两个以上的ISO-DEP块之间正确分割扩展长度的APDU,因此,假定大于261字节的APDU超过了发送缓冲区的大小.您仍然应该能够发送大小小于261字节的扩展长度的APDU.
因此isoDep.isExtendedLengthApduSupported()实际上指示您是否可以在一个ISO-DEP收发中发送超过261个字节.
解决此问题的方法是完全不使用IsoDep对象,而是在NfcA对象(如果您的卡基于)上手动实现ISO-DEP(ISO / IEC 14443-4传输协议). NFC-A / ISO / IEC 14443 Type A)或NfcB对象(如果您的卡基于NFC-B / ISO / IEC 14443 Type B,并且您的设备支持通过NfcB对象交换数据).然后,您可以将扩展长度的APDU拆分为对于NFC控制器的收发缓冲区足够小的ISO-DEP块(通常为253个字节,包括标头字节,不包括CRC字节).但是,自己处理ISO-DEP协议还意味着您必须注意正确的ISO-DEP激活,处理块编号,块确认,超时,等待时间扩展等.这相当复杂,尤其是超时由于Android NFC堆栈存在延迟,因此不容易观察.
标签:apdu,nfc,contactless-smartcard,javacard,android 来源: https://codeday.me/bug/20191118/2024872.html