我已经使用StackOverflow多年了,总是在提问之前就能找到答案,但今天我卡住了。
由于我恰好有一个工作的POS终端(EMV Chip&Pin类型),我想研究主机卡模拟。
终端可以使用最新版本的Tapp,所以我知道终端是好的,我的N7配备了Kitkat,实际上可以进行付款(或者至少终端会发出一系列良好的哔哔声,平板电脑启动了Tapp的注册屏幕)。 因此,我阅读了手册并编写了一堆代码,目的是在我的
但是“支付”部分不起作用:只有来自POS终端的两个高音哔哔声,平板电脑上没有任何内容。我的
我尝试了各种不同的AID:真实的和愚蠢的,短的和长的,但都没有效果。
当使用Tapp时,LogCat会显示:
很明显,我的代码没有让操作系统将HCE意图绑定到我的服务上。为什么呢?
以下是我的清单文件:
由于我恰好有一个工作的POS终端(EMV Chip&Pin类型),我想研究主机卡模拟。
终端可以使用最新版本的Tapp,所以我知道终端是好的,我的N7配备了Kitkat,实际上可以进行付款(或者至少终端会发出一系列良好的哔哔声,平板电脑启动了Tapp的注册屏幕)。 因此,我阅读了手册并编写了一堆代码,目的是在我的
HostApduService
上看到一些东西。
它部分地起作用,因为我可以在平板电脑的Tap&Pay设置中找到我的虚拟“卡”。但是“支付”部分不起作用:只有来自POS终端的两个高音哔哔声,平板电脑上没有任何内容。我的
HostApduService
没有被调用。我尝试了各种不同的AID:真实的和愚蠢的,短的和长的,但都没有效果。
当使用Tapp时,LogCat会显示:
11-17 14:51:47.690: D/BrcmNfcJni(3183): RoutingManager::stackCallback: event=0x18
11-17 14:51:47.690: D/HostEmulationManager(3183): notifyHostEmulationActivated
11-17 14:51:47.690: D/BrcmNfcJni(3183): RoutingManager::stackCallback: event=0x17
11-17 14:51:47.690: D/BrcmNfcJni(3183): RoutingManager::stackCallback: NFA_CE_DATA_EVT; h=0x302; data len=20
11-17 14:51:47.690: D/HostEmulationManager(3183): notifyHostEmulationData
11-17 14:51:47.700: D/HostEmulationManager(3183): Service already bound as payment service.
11-17 14:51:47.700: D/HostEmulationManager(3183): Binding to existing service
11-17 14:51:49.932: D/BrcmNfcJni(3183): RoutingManager::stackCallback: event=0x19
11-17 14:51:49.932: D/HostEmulationManager(3183): notifyHostEmulationDeactivated
11-17 14:51:49.932: E/BrcmNfcNfa(3183): UICC[0x0] is not activated
使用我的代码,LogCat输出为:
11-17 14:41:52.079: D/BrcmNfcJni(3183): RoutingManager::stackCallback: event=0x18
11-17 14:41:52.079: D/HostEmulationManager(3183): notifyHostEmulationActivated
11-17 14:41:52.089: D/BrcmNfcJni(3183): RoutingManager::stackCallback: event=0x17
11-17 14:41:52.089: D/BrcmNfcJni(3183): RoutingManager::stackCallback: NFA_CE_DATA_EVT; h=0x302; data len=20
11-17 14:41:52.089: D/HostEmulationManager(3183): notifyHostEmulationData
11-17 14:41:53.340: D/BrcmNfcJni(3183): RoutingManager::stackCallback: event=0x19
11-17 14:41:53.340: D/HostEmulationManager(3183): notifyHostEmulationDeactivated
11-17 14:41:53.340: E/BrcmNfcNfa(3183): UICC[0x0] is not activated
很明显,我的代码没有让操作系统将HCE意图绑定到我的服务上。为什么呢?
以下是我的清单文件:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="net.remolagi.hcetestbanque2"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="19"
android:targetSdkVersion="19" />
<uses-permission android:name="android.permission.NFC" />
<uses-feature
android:name="android.hardware.nfc.hce"
android:required="true" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="net.remolagi.hcetestbanque2.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<service
android:name=".MyHCEService"
android:exported="true"
android:permission="android.permission.BIND_NFC_SERVICE" >
<intent-filter>
<action android:name="android.nfc.cardemulation.action.HOST_APDU_SERVICE" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
<meta-data
android:name="android.nfc.cardemulation.host_apdu_service"
android:resource="@xml/apduservice" />
</service>
</application>
</manifest>
我的apduservice.xml:
<?xml version="1.0" encoding="UTF-8"?>
<host-apdu-service xmlns:android="http://schemas.android.com/apk/res/android"
android:description="@string/servicedesc"
android:requireDeviceUnlock="true"
android:apduServiceBanner="@drawable/payment_banner">
<aid-group android:description="@string/aiddescription"
android:category="payment">
<aid-filter android:name="A0000000031010"/>
</aid-group>
</host-apdu-service>
为了更好的效果,该服务(目前只能看到它记录日志):
package net.remolagi.hcetestbanque2;
import android.nfc.cardemulation.HostApduService;
import android.os.Bundle;
import android.util.Log;
public class MyHCEService extends HostApduService {
private static final String TAG = "MyHCEService";
@Override
public void onDeactivated(int arg0) {
Log.i(TAG, "OnDeactivated - arg0 : " + String.valueOf(arg0));
// TODO Auto-generated method stub
}
@Override
public byte[] processCommandApdu(byte[] arg0, Bundle arg1) {
Log.i(TAG, "Hooza ! processCommandApdu");
return arg0;
}
}
如果您对为什么它不起作用有任何想法,我将永远感激。目前我被难住了。
敬礼
Philippe