Android中的Manifestxml文件详解
每一个Android项目都包含一个清单(Manifest)文件,即AndroidManifest.xml,它位于项目层次结构的最底层。清单用于定义应用程序及其组件的结构和元数据。
AndroidManifest.xml文件包含了组成应用程序的各个组件(如活动、服务、内容提供器和广播接收器)的节点,并通过Intent过滤器和权限来确定这些组件之间以及这些组件与其他应用程序之间的交互方式。此外,它还提供了各种属性来详细说明应用程序的元数据(如图标或主题),以及进行安全设置和单元测试所需的顶级节点。
一个典型的AndroidManifest.xml文件结构如下:
```xml
package="com.my_domain.my_app"> [ ... manifest nodes ... ]
```
其中,`manifest`标签包含了一些节点(node),它们定义了应用程序组件、安全设置和组成应用程序的测试类。以下是一些常用的manifest节点标签及其用法:
1. `application`:一个清单只能包含一个`application`节点。它使用各种属性来指定应用程序的各种元数据(包括标题、图标和主题)。同时,它还可以作为一个容器,包含了活动、服务、内容提供器和广播接收器标签,用来指定应用程序组件。例如:
```xml
[ ... application nodes ... ]
```
2. `activity`:用于定义应用程序的活动组件。它可以包含属性来指定活动的布局、启动模式、任务栈等信息。例如:
```xml
```
3. `service`:用于定义应用程序的服务组件。它可以包含属性来指定服务的类型、绑定方法等信息。例如:
```xml
```
4. `contentProvider`:用于定义应用程序的内容提供器组件。它可以包含属性来指定内容提供器的URI路径、授权等信息。例如:
```xml
```
5. `receiver`:用于定义应用程序的广播接收器组件。它可以包含属性来指定接收器的注册类、广播类型等信息。例如:
```xml
```
在 Android 应用程序中,每个 Activity 都必须有一个 activity 标签,并使用 android:name 属性来指定类的名称。这个类名需要包括启动该 Activity 的核心类以及其他所有可以显示的屏幕或对话框。如果试图启动一个未在清单文件中定义的 Activity,将抛出一个运行时异常。
每个 Activity 节点都可以使用 intent-filter 子标签来指定哪个 Intent 将启动该活动。例如,以下代码展示了一个名为“.MyActivity”的活动,它的标签是应用的名称:
```xml
```
此外,还有 provider 标签,用于说明应用程序中的每一个内容提供器。内容提供器负责管理数据库访问以及程序内和程序间的数据共享。例如,以下代码展示了一个名为 ".MyContentProvider" 的内容提供器,它具有一个自定义权限、启用状态以及授权机构:
```xml
android:permission="com.liujc.MY_PERMISSION" android:name=".MyContentProvider" android:enabled="true" android:authorities="com.liujc.myapp.MyContentProvider">
```
最后,还有 receiver 标签,用于声明接收器组件。接收器组件是用于处理来自其他应用程序的消息和通知的组件。
在Android开发中,我们可以使用以下几个标签来实现应用程序的自动化和安全性:
1. receiver标签:通过添加receiver标签,可以注册一个广播接收器(Broadcast Receiver),而不用事先启动应用程序。广播接收器就像全局事件监听器一样,一旦注册了之后,无论何时,只要与它相匹配的intent被应用程序广播出来,它就会立即执行。通过在声明中注册一个广播接收器,可以使这个进程实现完全自动化。如果一个匹配的Intent被广播了,则应用程序就会自动启动,并且你注册的广播接收器也会开始运行。示例代码如下:
```xml
```
2. service标签:Service作为Android四大组件之一,在每一个应用程序中都扮演着非常重要的角色。它主要用于在后台处理一些耗时的逻辑,或者去执行某些需要长期运行的任务。示例代码如下:
```xml
```
3. uses-permission标签:作为安全模型的一部分,uses-permission标签声明了那些由你定义的权限,而这些权限是应用程序正常执行所必需的。在安装程序的时候,你设定的所有权限将会告诉给用户,由他们来决定同意与否。对很多本地Android服务来说,权限都是必需的,特别是那些需要付费或者有安全问题的服务(例如,拨号、接收SMS或者使用基于位置的服务)。示例代码如下:
```xml
```
4. permission标签:第三方应用程序,包括你自己的应用程序,也可以在提供对共享的程序组件进行访问之前指定权限。示例代码如下:
```xml
```
在限制访问某个应用程序组件之前,首先需要在清单文件(AndroidManifest.xml)中定义一个权限。可以使用permission标签来创建这些权限定义。然后,应用程序组件就可以通过添加android:permission属性来要求这些权限。接着,其他应用程序就需要在它们的清单文件中包含uses-permission标签(并通过授权),之后才能使用这些受保护的组件。
在uses-permission标签内,可以详细指定允许的访问权限的级别(normal、dangerous、signature、signatureOrSystem)、一个 label属性和一个外部资源,这个外部资源应该包含了对授予这种权限的风险的描述。以下是一个示例代码:
```xml
android:name="com.liujc.DETONATE_DEVICE" android:protectionLevel="dangerous" android:label="Self Destruct" android:description="@string/detonate_description" /> ``` 接下来,我们来讨论instrumentation类。instrumentation类提供一个框架,用来在应用程序运行时在活动或者服务上运行测试。它们提供了一些方法来监控应用程序及其与系统资源的交互。对于为自己的应用程序所创建的每一个测试类,都需要创建一个新的节点。例如,以下代码展示了如何定义一个名为"My Test"的测试类,该类针对的目标包名为"com.liujc.test": ```xml android:label="My Test" android:name=".MyTestClass" android:targetPackage="com.liujc.test" /> ``` 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!