我有一个免费的应用程序,其中还包含专业版功能,如果用户在Android电子市场中为我的应用购买了专业版密钥,则可供用户使用。我在专业应用程序中设置了一个接收器,在主应用程序中设置了另一个接收器。当用户单击主应用程序中的“验证密钥”按钮时,会在密钥应用程序中向接收方广播一个意图,然后启动IntentService以检查专业密钥许可证是否有效。然后,IntentService向主应用接收器广播一个意图,其中包含来自LVL检查的额外“响应”。
我快到了。只有当我尝试在IntentService中进行LVL检查时,才会出现错误:
W/MessageQueue(2652): java.lang.RuntimeException: Handler{4052de20} sending message to a Handler on a dead thread
W/MessageQueue(2773): at com.android.vending.licensing.LicenseChecker$ResultListener.verifyLicense(LicenseChecker.java:207)
有什么建议吗?
IntentService来源:
public class CheckerService extends IntentService {
private static final byte[] SALT = ....;
private static final String BASE64_PUBLIC_KEY = ...;
private String device_id;
public CheckerService() {
super("CheckerService");
}
@Override
protected void onHandleIntent(Intent intent) {
SharedPreferences data = getSharedPreferences("data", MODE_PRIVATE);
device_id = data.getString("device_id", null);
if (device_id == null) {
SharedPreferences.Editor editor = data.edit();
device_id = new DeviceId().generate(this);
editor.putString("device_id", device_id);
editor.commit();
}
ServerManagedPolicy smp = new ServerManagedPolicy(this,
new AESObfuscator(SALT, getPackageName(), device_id));
LicenseChecker checker = new LicenseChecker(this, smp, BASE64_PUBLIC_KEY);
checker.checkAccess(new LicenseCheckerCallback(){
public void allow() {
Intent i = new Intent();
i.setAction("com.mainapp.intent.action.LICENSE_RESPONSE");
i.putExtra("response", "LICENSE_OK");
sendBroadcast(i);
}
public void dontAllow() {
Intent i = new Intent();
i.setAction("com.mainapp.intent.action.LICENSE_RESPONSE");
i.putExtra("response", "LICENSE_NOT_OK");
sendBroadcast(i);
}
public void applicationError(ApplicationErrorCode errorCode) {
Intent i = new Intent();
i.setAction("com.mainapp.intent.action.LICENSE_RESPONSE");
i.putExtra("response", "LICENSE_ERROR");
sendBroadcast(i);
}});
}
@Override
public void onDestroy() {
super.onDestroy();
checker.onDestroy();
}
}
答案 0 :(得分:0)
我相信这个问题与IntentService有关。 IntentService管理它自己的生命周期。本质上,它只是一个在非UI线程上运行的服务。在回调可以处理之前,服务被销毁,所以当回调发生时,没有任何东西可以“回调”到。
您可以尝试在START_STICKY或START_NOT_STICKY的服务中运行它,并自行管理生命周期。