使用android:protectionLevel =“signature”的问题

时间:2012-11-27 12:22:02

标签: android android-service

我试图阻止应用程序绑定到服务,如果它们没有使用与包含应用程序相同的证书进行签名。为此,我通过使用元素在清单(包含服务的应用程序)中声明了一个新权限,并将新权限的protectionLevel设置为Signature,如图所示。

<permission android:name="jp.co.abc.android.OMRSSettings.permission.Access"
android:protectionLevel="signature"></permission>

<uses-permission android:name="jp.co.abc.android.OMRSSettings.permission.Access"/>

然后,在服务的清单声明中,我使用了android:permission属性,因此需要这个新权限绑定到服务。

<service android:name="jp.co.xyz.bluetooth.profile.TIPServer"
 android:permission="jp.co.abc.android.OMRSSettings.permission.Access" >
<intent-filter>
<action android:name="jp.co.xyz.bluetooth.api.ICommonResultCallback" />
<action android:name="jp.co.xyz.bluetooth.api.ITimeServer" />
</intent-filter>

我尝试从其他应用程序访问此服务。在第二个应用程序的清单中,我添加<uses-permission android:name="jp.co.abc.android.OMRSSettings.permission.Access"/>并尝试绑定到第一个应用程序的服务。

但我得到以下例外。

01-02 00:06:54.531: INFO/PowerManagerService(425): Start Light.setBrightness(), [20],  [3]
01-02 00:06:56.473: INFO/PowerManagerService(425): Start Light.setBrightness(), [130], [3]
01-02 00:06:58.055: WARN/dalvikvm(4956): threadid=1: thread exiting with uncaught exception (group=0x40b70390)
01-02 00:06:58.055: WARN/ActivityManager(425): Permission Denial: Accessing service ComponentInfo{jp.co.abc.android.omrsettings/jp.co.xyz.bluetooth.profile.TIPServer} from   pid=4956, uid=10158 requires jp.co.abc.android.OMRSSettings.permission.Access
01-02 00:06:58.065: ERROR/AndroidRuntime(4956): FATAL EXCEPTION: main
java.lang.SecurityException: Not allowed to bind to service Intent {     act=jp.co.xyz.bluetooth.api.ITimeServer }
at android.app.ContextImpl.bindService(ContextImpl.java:1187)
at android.content.ContextWrapper.bindService(ContextWrapper.java:370)
at jp.co.abc.middleware.tip.LeTimeServerProfile.startTimeServer(LeTimeServerProfile.java:45)
at jp.co.abc.tip.TimeActivity.onClick(TimeActivity.java:49)
at android.view.View.performClick(View.java:3511)
at android.view.View$PerformClick.run(View.java:14133)
at android.os.Handler.handleCallback(Handler.java:605)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4507)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:787)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:554)
at dalvik.system.NativeStart.main(Native Method)
01-02 00:06:58.095: WARN/ActivityManager(425): Force finishing activity      jp.co.abc.tip/.TimeActivity

如果我在第二个应用的清单中正确声明<uses-permission android:name="jp.co.abc.android.OMRSSettings.permission.Access"/>,有人可以告诉我为什么我有权限问题。

非常感谢任何帮助。

修改

修改后包括他答案中建议的修正lenik。

2 个答案:

答案 0 :(得分:5)

除了lenik的解决方案,不要弄乱您的权限名称,使用您当前的实现,安装顺序很重要。在安装客户端之前,必须先安装服务(定义{{​​1}}的位置)。否则,客户端将无法获得该权限,因为Android会忽略<permission>以获取其无法识别的权限。如果您将<uses-permission>元素放在两个应用中(具有相同的值),则安装顺序将不再重要。

答案 1 :(得分:3)

您要求的许可是:

<permission android:name="jp.co.abc.android.OMRSSettings.permission.Access"

,你的日志说:

requires jp.co.abc.android.OMRSettings.permission.Access

你应该决定在两种情况下使用“OMRS”或“OMR”,一个“S”是额外的。