manifest节点
xmlns:android属性——定义命名空间
这个属性定义了这个XML文件所使用的命名空间。如果需要指定特殊的命名空间,就需要手动编写代码,在Android Studio基本格式如下:
xmlns:<命名空间标识>="http://schemas.android.com/apk/res-auto"
package属性——应用程序的唯一标识
要是我安装另一个有相同package属性的应用程序,会有什么事情发生呢?会提示如下错误:
Failure[INSTALL_FAILED_ALREADY_EXSIST]
注意:除非特殊需要,否则不建议修改package属性的值!原因是package是唯一标识了
我们应用程序的属性,如果你试图改变它的值,那么系统通常会认为这是一个不同的
应用程序,会导致拥有前一版本应用程序的用户无法拥有新版本的应用程序。
android:sharedUserId属性——共享数据
该属性定义了需要和其他应用程序共享的Linux用户ID。
默认情况下,Android系统为每一个应用程序分配一个唯一的用户ID。然而,
当这个属性在多个应用程序中被设置为相同值的时候,它们将共享一个用户ID。
这样做的好处是,它们之间可以相互访问彼此的数据,如有需要,它们还将在相同的
进程中运行。应用没有设置这个属性,这就意味着它没有和别的应用程序存在共享关系,
这样它们之间就需要通过其他手段(如进程间通信)实现数据互访。
与android:sharedUserId属性相关的属性还有android:sharedUserLabel,
这个属性给共享的用户ID定义了一个用户可读的标签。这个标签必须用字符串资源来设置,
不能使用原生的字符串。这个属性在API LEVEL3中引用,只有设置了sharedUserId属性时才有意义。
android:versionCode属性——内部版本号
versionCode属性的值是一个内部版本号,用于确定这个版本是否比另一个版本更新,
数字越大表明它就越新。它不是显示给用户看的版本号,而是由versionName属性设置的号码。
版本号将决定一些服务的行为,比如替换应用程序时是否执行备份还原操作等。
该号码必须设为整数,递增的!
android:versionName属性——显示给用户的版本号
versionName属性的值是显示给用户的版本号,它可以被设置为一个原始字符串
或者一个字符串资源的引用。这个字符串除了要显示给用户外,没有其他的目的。
如版本号为1.1.0
android:installLocation属性——安装位置
该属性定义了应用程序默认的安装位置,共有3个可选值,其形式如下:
android:installLocation=["auto"|"internalOnly"|"preferExternal"]
下表说明了这3个可选值的含义。
值 | 描述 |
auto |
应用程序可能被安装到外部存储设备中,但默认情况下系统将会把应用程序安装到内部存储设备中。 如果内存不足,那么系统将会把应用程序安装到外部存储设备中。 |
internalOnly |
应用程序必须安装到设备的内部存储设备中。如果设置了这个值,那意味着应用程序将永远不会安装 到外部存储设备中去。如果内存不足,那么系统将不会安装这个APK。在没有 设置android:installLocation属性的情况下,internalOnly是该属性的默认值。 |
preferExternal |
应用程序将会被安装到外部存储设备中,如果系统不支持外部存储设备或者外部设备已满, 那么系统将会把这个应用程序安装到内部存储设备中。 |
<uses-permission>——应用程序的权限申请
该属性为用户权限,应用使用中如果没有相应的权限,就无法创建文件,
而程序并没有显示一个异常的提示,这时我们就可能要花费大量的时间去找问题的根源。
建议开发之前仔细分析需求,分析应用为什么功能,而这些动能是否需要权限才可以访问。
<permission>节点——自定义应用程序的访问权限
定义自己的权限,用来限制对本应用程序或其他应用程序的特殊组件或功能访问
手动向AndroidManifest.xml文件中添加一个<permission>节点,它只能包含在<manifest>节点下,
语法如下所示:
<permission android:description="string resource" android:icon="drawable resource" android:logo="drawable resource" android:label="string resource" android:name="string" android:permissionGroup="string" android:protectionLevel=["normal"|"dangerous"|"signature"|"signatureOrSystem"]/>
3个属性:
①android:name:声明权限的名称。这个名称必须是唯一的,因此,应该使用Java风格的命名,
比如com.test.permission.TEST。
②android:permissionGroup:声明权限从属于哪一个权限组,这个权限组可以是Android预编译的,
也可以是自定义的。下表列除了Android系统预编译的系统权限组。
权限组名称 | 描述 |
android.permission-group.ACCOUNTS | 用于直接访问由帐号管理器管理的帐号 |
android.permission-group.COST_MONEY | 用于使用户不需要直接参与就可花钱的权限 |
android.permission-group.DEVELOPMENT_TOOLS | 与开发特征相关的权限群 |
android.permission-group.HARDWARE_CONTROLS | 用于提供直接访问设备硬件的权限 |
android.permission-group.LOCATION | 用于允许用户访问用户当前位置的权限 |
android.permission-group.MESSAGES |
用于允许应用程序以用户的名义发送信息或者 拦截用户收到的信息的权限 |
android.permission-group.NETWORK | 适用于提供网络服务的访问权限 |
android.permission-group.PERSONAL_INFO |
适用于提供访问到用户私人数据的权限, 如联系人,日历事件和电子邮件信息 |
android.permission-group.PHONE_CALLS |
适用于关联访问和修改电话状态的权限, 比如拦截去电,读取和修改电话的状态 |
android.permission-group.STORAGE | 与SD卡访问有关的权限组 |
android.permission-group.SYSTEM_TOOLS | 与系统API有关的权限组 |
③android:protectionLevel:描述了隐含在权限中的潜在风险,该属性的值可以是下表中的一个字符串。
值 | 意义 |
normal |
默认值。低风险的权限,它可以使请求的应用程序访问孤立的应用程序级的功能, 给其他应用程序,系统或者用户带来最小的风险。系统在安装时,会自动授予 这种类型的权限给请求的应用程序,无须用户明确声明。 |
dangerous |
高风险权限,它将事请求的应用程序能访问用户的私有数据或者控制那些会 对用户产生负面影响的设备。由于这种权限存在潜在的风险,系统可能不会 自动被赋予请求的应用程序。例如,任何一个由应用程序请求的危险权限可能 会显示给用户,并且在处理之前被要求确认。例如,以下权限就属于此类权限。 此时我们认为使用这种权限是危险的。 |
signature |
签名级别。系统只在请求的应用程序用同样的签名作为声明权限时才授予该权限。 如果认证匹配,则系统不通知用户或者无须用户明确批准就可以自动授权。 |
signatureOrSystem |
签名或者系统级别。系统仅仅将它授给Android系统镜像文件(*.img文件)中的应用程序, 或者是和系统镜像中的那些用同样认证签名的应用程序。一般情况下,尽量避免使用该选项, 这是由于signature保护层级应满足大多数需求和工程,而不管应用程序被确切地安装在何处。 signatureOrSystem权限适用于特定的特殊环境,在这样的环境里, 多个厂商已经将应用程序构建到系统镜像中,并且需要明确共享特定特征。 |
manifest节点的更多相关文章
- Android读取Manifest文件下Application等节点下的metadata自定义数据
介绍 Android在 提供了meta-date使用键值对的形式实现自定义配置.一般使用中作为渠道标识.可以用 在<application>,<activity>,<ac ...
- Android 阅读Manifest在文件Application 在与其他节点meta-data定义自己的数据
介绍 Android提供meta-date使用键值在实现自己的自定义配置的形式. 通常用作信道标识.它可以用在<application>,<activity>,<acti ...
- Android清单文件详解(三)----应用程序的根节点<application>
<application>节点是AndroidManifest.xml文件中必须持有的一个节点,它包含在<manifest>节点下.通过<application>节 ...
- Android清单文件具体解释(三)----应用程序的根节点<application>
<application>节点是AndroidManifest.xml文件里必须持有的一个节点,它包括在<manifest>节点下.通过<application>节 ...
- <application>节点属性
1.android:allowBackup 它表示是否允许应用程序参与备份.如果将该属性设置为false,则即使备份整个系统,也不会执行这个应用程序的备份操作,而整个系统备份能导致所有应用程序数据通过 ...
- application节点
<application>节点是AndroidManifest.xml文件中必须持有的一个节点,它包含在<manifest>节点下.通过<application>节 ...
- Android(2)—Mono For Android App版本自动更新
0.前言 公司Android查询的项目已经开始,整体采用Java后台+App前台来实现,由于项目小,App这块就我一个人开发,首先需要研究的是:Android版本的更新升级问题:本人经过近一周的学习整 ...
- Android安全开发之通用签名风险
Android安全开发之通用签名风险 作者:伊樵.舟海.呆狐@阿里聚安全 1 通用签名风险简介 1.1 Android应用签名机制 阿里聚安全漏洞扫描器有一项检测服务是检测APP的通用签名风险.And ...
- Android(Java)控制GPIO的方法及耗时分析
前面两篇分别介绍了通过脚本和C代码读写/sys/class/gpio以控制GPIO.实际项目调试时经常还需要在Java代码里控制GPIO,其实现与C代码类似,唯一不同是Android权限.本文重点介绍 ...
随机推荐
- Python学习记录6-list、tuple、dict、set复习
数据类型在一门语言中是非常重要的,所以选择再次学习一下加深记忆.本次主要参考了大神廖雪峰的官方网站,非常感谢大神,讲的很清晰,收获很大. 标准数据类型 Number(数字) String(字符串) L ...
- python pip 'nonetype' object has no attribute 'bytes'
python pip 'nonetype' object has no attribute 'bytes' 更新 pip for Windows : python -m pip install -U ...
- lnmp配置
yum源切换 下载wegt工具 yum install -y wget 备份 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS- ...
- crontab踩坑(二):Unit crond.service could not be found.
这是因为Ubuntu上的服务名称是cron不是crond.所以你的命令应该是: sudo service cron start
- Tomcat配置多站点
tomcat配置多个站点.可以这样. 在conf文件夹下创建文件:..conf\Catalina\localhost\aa.xml aa.xml的内容.如: <?xml version=&quo ...
- 题解 [51nod1161] Partial Sums
题面 解析 我们设\(f[i]\)表示\(k\)次操作后第一个数在第\(i\)个位置上加了多少次, 而其它的数也可以类推, 第\(i\)个数在第\(j\)个位置加的次数就是\(f[j-i+1]\). ...
- 【Python之路】特别篇--基于领域驱动模型架构设计的京东用户管理后台
一.预备知识: 1.接口: - URL形式 - 数据类型 (Python中不存在) a.类中的方法可以写任意个,想要对类中的方法进行约束就可以使用接口: b.定义一个接口,接口中定义一个方法f1: c ...
- umei-spider
umei-spider 1 #!/usr/bin/python3 2 3 import requests 4 from bs4 import BeautifulSoup 5 from contextl ...
- python 系统模块 OS
os.system("系统命令") 调用系统命令 os.system("task kill /f /im 系统的进程") 关闭系统进程 os.listdir( ...
- 用sql语句查询一列名中的各个数值的个数
SELECT COUNT(case when f.fileState=2 then 0 end) as fixed,COUNT(case when f.fileState=3 then 0 end) ...