在接入第三方渠道SDK的时候,经常会看到其配置文件AndroidManifest.xml有类似如下的定义:
  1. <!-- appid -->
  2. <meta-data
  3. android:name="APP_ID"
  4. android:value="037810BCE1D2260F32017643AC7D980C" />
  5. <!-- 发布渠道(可选) -->
  6. <meta-data
  7. android:name="APP_CHANNEL"
  8. android:value="QQ_CENTER" />

标签<meta-data>是提供组件额外的数据用的,它本身就是一个键值对,可以自定义名称和值。它可以包含在以下组件当中:

<meta-data android:name="appid" android:value="b03c5cfef65ed30108f0a3fd82c3f6b4" />
<meta-data android:name="appsecret" android:value="LWLPg7pU4cwrcyy8PwDeGuaY0BHUoX" />

<meta-data android:name="appkey" android:value="110000" />

这三个标签是写在application下面的。后来我又搜了一下,meta-data还可以出现在activity,receiver,service标签中。包括上面的application中。一共有四个地方可以使用到。

一,在activity中

xml中配置如下

  1. <!-- Activity -->
  2. <activity android:name=".MyActivity" android:label="@string/app_name">
  3. <intent-filter>
  4. <action android:name="android.intent.action.MAIN" />
  5. <category android:name="android.intent.category.LAUNCHER" />
  6. </intent-filter>
  7. <meta-data android:name="activity_name" android:value="activity_value" />
  8. </activity>

java代码如下

  1. ActivityInfo actInfo = mContext.getPackageManager().getActivityInfo(
  2. getComponentName(), PackageManager.GET_META_DATA);
  3. String msg = actInfo.metaData.getString("activity_name");

二,在service中

xml中配置如下

  1. <!-- 服务 -->
  2. <service android:name=".MyService">
  3. <meta-data android:name="service_name" android:value="service_value" />
  4. </service>

java代码如下

  1. ComponentName cn = new ComponentName(this, MyService.class);
  2. try {
  3. ServiceInfo serInfo = this.getPackageManager().getServiceInfo(cn,
  4. PackageManager.GET_META_DATA);
  5. } catch (NameNotFoundException e) {
  6. e.printStackTrace();
  7. }
  8. String msg = serInfo.metaData.getString("service_name");

三,在application中

xml中配置如下

  1. <!-- app -->
  2. <meta-data android:name="application_name" android:value="application_value" />

java代码如下

  1. ApplicationInfo appInfo = this.getPackageManager().getApplicationInfo(
  2. getPackageName(), PackageManager.GET_META_DATA);
  3. String msg = appInfo.metaData.getString("application_name");

四,在receiver中,也就是广播接收者(拨打电话的时候会看到toast消息)
xml中配置如下

  1. <receiver android:name=".MyReceiver">
  2. <meta-data android:name="receiver_name" android:value="receiver_value" />
  3. <intent-filter>
  4. <action android:name="android.intent.action.PHONE_STATE" />
  5. </intent-filter>
  6. </receiver>

java代码如下

  1. if (TextUtils.equals("android.intent.action.PHONE_STATE", intent
  2. .getAction())) {
  3. ComponentName cn = new ComponentName(context, MyReceiver.class);
  4. try {
  5. ActivityInfo info = context.getPackageManager().getReceiverInfo(cn,
  6. PackageManager.GET_META_DATA);
  7. } catch (NameNotFoundException e) {
  8. e.printStackTrace();
  9. }
  10. String msg = info.metaData.getString("receiver_name");
  11. // 打电话测试即可
  12. Toast.makeText(context, msg, Toast.LENGTH_SHORT).show();
  13. }

总结:

这个数据配置为什么要这么写,我还没发现它的好,以后慢慢领悟再来续写。

我觉得大可以写一个ConstData类来存放id,key之类的参数。

用meta-data配置参数的更多相关文章

  1. Scala调用Kafka的生产者和消费者Demo,以及一些配置参数整理

    kafka简介 Kafka是apache开源的一款用Scala编写的消息队列中间件,具有高吞吐量,低延时等特性. Kafka对消息保存时根据Topic进行归类,发送消息者称为Producer,消息接受 ...

  2. MySQL Cluster 7.3.5 集群配置参数优化(优化篇)

    按照前面的教程:MySQL Cluster 7.3.5 集群配置实例(入门篇),可快速搭建起基础版的MySQL Cluster集群,但是在生成环境中,还是有很多问题的,即配置参数需要优化下, 当前生产 ...

  3. mha配置参数详解

    mha配置参数详解: 参数名字 是否必须 参数作用域 默认值 示例 hostname Yes Local Only - hostname=mysql_server1, hostname=192.168 ...

  4. MySql配置参数很全的Mysql配置参数说明

    MySql配置参数 很全的Mysql配置参数说明 1. back_log 指定MySQL可能的连接数量.当MySQL主线程在很短的时间内得到非常多的连接请求,该参数就起作用,之后主线程花些时间(尽管很 ...

  5. Spark配置参数详解

    以下是整理的Spark中的一些配置参数,官方文档请参考Spark Configuration. Spark提供三个位置用来配置系统: Spark属性:控制大部分的应用程序参数,可以用SparkConf ...

  6. MongoDB启动文件配置参数详解

    接手的MongoDB只有一个日志文件,体积非常大,排错不便.在找解决办法的时候发现MongoDB的启动文件配置项超级多,于是产生了解释配置参数的想法. mongod服务有两种启动方式 一种是通过配置文 ...

  7. 【记】研究Sharding-JDBC遇到的一个异常(Caused by: io.shardingsphere.core.exception.ShardingException: Cannot get uniformed table structure for `t`. The different meta data of actual tables are as follows)

    一.异常信息 Caused by: io.shardingsphere.core.exception.ShardingException: Cannot get uniformed table str ...

  8. MHA配置参数详解 【转】

    mha配置参数详解: 参数名字 是否必须 参数作用域 默认值 示例 hostname Yes Local Only - hostname=mysql_server1, hostname=192.168 ...

  9. php源码安装常用配置参数和说明

    常用的配置参数1. --prefix=/usr/local/php 指定 php 安装目录 install architecture-independent files in PREFIX 默认/us ...

  10. nfs的无敌时间更改的配置参数

    nfs服务端重启之后,共享文件夹进入grace time(无敌时间) 客户端在服务端重启后写入数据大概要等90秒 nfs配置文件:/etc/sysconfig/nfs [root@backup ~]# ...

随机推荐

  1. 【iOS】我的Objective-C学习笔记

    1.代码中增加标记 #pragma mark - #pragma mark 2.点语法 Person *p = [Person new]; // 点语法的本质还是方法调用 p.age = 10; // ...

  2. 无法嵌入互操作类型“ESRI.ArcGIS.Carto.RectangleElementClass”。请改用适用的接口。

    右键点击应用的程序集 ESRI.ArcGIS.Controls,修改"嵌入互操作类型"的值即可

  3. 使用servlet实现用户注册功能

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  4. 手机号码归属地查询api接口

    淘宝网 API地址: http://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=15850781443 参数: tel:手机号码 返回:JSON ...

  5. Vector成员为指针时要注意的问题

    vector的复制是浅复制,所以复制一个包含动态内存的变量的对象的话就会出问题. 解决办法:自己写类的复制构造函数,为新对象的指针开辟新的内存空间. 但当vector离开作用域之后,只会把其成员所占的 ...

  6. WCF 4.0 进阶系列 -- 随笔汇总

    WCF4.0 进阶系列–前言 WCF4.0 进阶系列--第一章 WCF简介 WCF4.0进阶系列--第二章 寄宿WCF服务 WCF4.0进阶系列--第三章 构建健壮的程序和服务 WCF4.0进阶系列- ...

  7. 微内核架构(Microkernel Architecture)

    微内核架构(Microkernel Architecture) 微内核架构有时也被成为插件架构模式(plug-in architecture pattern),通常用于实现基于产品的应用,如Eclip ...

  8. mybatis批量更新 UPDATE mysql

    oracle和mysql数据库的批量update在mybatis中配置不太一样: oracle数据库: <update id="batchUpdate" parameterT ...

  9. java 多线程—— 线程让步

    java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...

  10. jpype调用jar

    import easyguiimport osfrom jpype import * jarpath = "d:\jar"print "jarPath: %s" ...