AndroidManifest 中标签permission使用探索

AndroidManifest 中标签permission使用探索,第1张

AndroidManifest 中标签permission使用探索

配置文件中通常使用uses-permission标签来为APP声明权限,但是permission标签的使用一直以来都很模糊,主要是从来没用过,这次准备面试无意中升起关于permission的疑问就顺便试验了一番,有点效果,不足之处还望各方大佬多多指点。
permission标签是我们为自己的APP声明的自定义权限,如下声明在manifest节点下

 

属性介绍:

  • android:description:对权限的描述,比lable更加的详细,介绍该权限的相关使用情况,比如当用户被询问是否给其他应用该权限时。注意描述应该使用的是string资源,而不是直接使用string串。
  • android:icon:用来标识该权限的一个图标。
  • android:label:权限的一个给用户展示的简短描述。方便的来说,这个可以直接使用一个string字串来表示,但是如果要发布的话,还是应该使用string资源来表示。
  • android:name:权限的唯一名字,由于独立性,一般都是使用包名加权限名,该属性是必须的,其他的可选,未写的系统会指定默认值。
  • android:protectionLevel:权限的等级:normal、dangerous、signature、signatureOrSystem;.

权限等级说明:

  • normal:低风险权限,只要申请了就可以使用(在AndroidManifest.xml中添加标签),安装时不需要用户确认;
    dangerous:高风险权限,安装时需要用户的确认才可使用;
    signature:只有当申请权限的应用程序的数字签名与声明此权限的应用程序的数字签名相同时(如果是申请系统权限,则需要与系统签名相同),才能将权限授给它;
    signatureOrSystem:签名相同,或者申请权限的应用为系统应用(在system image中),与signature类似,只是增加了rom中自带的app的声明
    ,尽量不要使用该选项,因为signature已经适合绝大部分的情况。
      对于普通和危险级别的权限,我们称之为低级权限,应用申请即授予。其他两级权限,我们称之为高级权限或系统权限。当应用试图在没有权限的情况下做受限 *** 作,应用将被系统杀掉以警示。系统应用可以使用任何权限。权限的声明者可无条件使用该权限。
      
    测试:
    在APP01的
 

App02中的设置相应的权限即可打开APP01:


    

同理我们也可以在指定的某个activity中设置permission,这样APP02同样需要设置权限才能直接打MainActivity2(android:exported=“true” 这个设置不能省,否则外界APP无法打开目标activity)

					
										


					

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/zaji/3976785.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-10-21
下一篇 2022-10-21

发表评论

登录后才能评论

评论列表(0条)

保存