首先,我已经阅读了有关此标题的所有问题,但不是这些问题对我有帮助: - (
我必须使用我的客户端应用程序并使用权限连接到基本应用程序。如果我先安装客户端应用程序然后再安装基本应用程序,我就会遇到异常我该怎么解决这个问题?如果我删除了我的客户端应用程序并再次安装它,问题就解决了,但我怎么能告诉我的客户,如果没有安装基础应用程序,如何阻止他们安装客户端应用程序?
在Mypackage.IssueFirstLookActivity.onCreate(IssueFirstLookActivity.java:443)是:
mHelper.startSetup(new OnIabSetupFinishedListener()
在Mypackage.IabHelper.startSetup(IabHelper.java:269)是(mContext.bindService(serviceIntent, mServiceConn, Context.BIND_AUTO_CREATE);)
List<ResolveInfo> queryIntentServices = mContext.getPackageManager().queryIntentServices(serviceIntent, 0);
if (queryIntentServices != null && !queryIntentServices.isEmpty()) {
// service available to handle that Intent
mContext.bindService(serviceIntent, mServiceConn, Context.BIND_AUTO_CREATE);
}
和
mHelper = new IabHelper(this,mBase64EncodedPublicKey);
if(myContext.getState() == MyContext.LOGIN_HAS_NOT_PURCHASED_STATE ){
// if(1==1){
mHelper.startSetup(new OnIabSetupFinishedListener() {
@Override
public void onIabSetupFinished(IabResult result) {
// if we were disposed of in the meantime, quit.
if (mHelper == null) return;
if (!result.isSuccess()) {
// Oh noes, there was a problem.
Log.d(TAG, "Problem setting up In-app Billing: " + result);
Toast.makeText(IssueFirstLookActivity.this, "Error " + result.toString() ,Toast.LENGTH_LONG).show();
// TODO user has not bazaar
}else{
// Hooray, IAB is fully set up!
// TODO my new thing
//mHelper.queryInventoryAsync(mGotInventoryListener);
}
}
});
堆栈追踪:
04-10 10:44:42.170: E/AndroidRuntime(2316): FATAL EXCEPTION: main
04-10 10:44:42.170: E/AndroidRuntime(2316): java.lang.RuntimeException: Unable to start activity ComponentInfo{Mypackage.IssueFirstLookActivity}: java.lang.SecurityException: Not allowed to bind to service
Intent { act="Base app permission" pkg=base app package }
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ActivityThread.access$600(ActivityThread.java:141)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.os.Handler.dispatchMessage(Handler.java:99)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.os.Looper.loop(Looper.java:137)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ActivityThread.main(ActivityThread.java:5103)
04-10 10:44:42.170: E/AndroidRuntime(2316): at java.lang.reflect.Method.invokeNative(Native Method)
04-10 10:44:42.170: E/AndroidRuntime(2316): at java.lang.reflect.Method.invoke(Method.java:525)
04-10 10:44:42.170: E/AndroidRuntime(2316): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
04-10 10:44:42.170: E/AndroidRuntime(2316): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
04-10 10:44:42.170: E/AndroidRuntime(2316): at dalvik.system.NativeStart.main(Native Method)
04-10 10:44:42.170: E/AndroidRuntime(2316): Caused by: java.lang.SecurityException: Not allowed to bind to service Intent { act="Base app permission" pkg=base app package }
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ContextImpl.bindServiceAsUser(ContextImpl.java:1478)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ContextImpl.bindService(ContextImpl.java:1448)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.content.ContextWrapper.bindService(ContextWrapper.java:496)
04-10 10:44:42.170: E/AndroidRuntime(2316): at Mypackage.IabHelper.startSetup(IabHelper.java:269)
04-10 10:44:42.170: E/AndroidRuntime(2316): at Mypackage.IssueFirstLookActivity.onCreate(IssueFirstLookActivity.java:443)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.Activity.performCreate(Activity.java:5133)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
04-10 10:44:42.170: E/AndroidRuntime(2316): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
04-10 10:44:42.170: E/AndroidRuntime(2316): ... 11 more
答案 0 :(得分:2)
如果我正确解释您的编辑Intent
,它至少包含其中的包,这意味着Android 5.0&#34;无法绑定到隐式Intent
&# 34;问题无关紧要。 OTOH,如果你没有许可,我原本期望更多关于错误的权限。
如果客户端应用和基础应用都属于您自己,particularly on Android 5.0+,您可以将<permission>
元素放在两个应用中,您应该没问题。 Xaver Kapeller在评论中指出的安全漏洞是因为,在Android 5.0之前,任何应用程序都可以尝试重新定义您的自定义权限。但是,如果客户端应用程序和基本应用程序来自不同的作者,或者具有不同的签名密钥,则他们不能同时尝试声明<permission>
。
但我怎么能告诉我的客户
假设您不能同时使用这两个应用声明<permission>
...
选项#1:首先尝试以这种方式连接多个应用。
选项#2:在产品列表中非常仔细地解释(例如,Play商店)。
选项#3:在您的客户端应用程序运行时(通过PackageManager
)查找您的基本应用程序,并向用户解释客户端应用程序实际上是基本应用程序的插件,因此基本应用程序需要是首先安装。
如果未安装基础应用,如何阻止他们安装客户端应用?
只有首先没有两个应用程序。