讲到这里,可能就会有人问了,这个东西什么用啊?我自己程序里用这个配置拿自己的数据,那不是脱裤子放屁?
别急…一开始就说到了< meta-data>这个标签经常是在接入第三方SDK时见到,那么它的应用场景肯定跟SDK开发有关啊!并且在系统属性配置上也有应用,比如配置屏幕支持比例,配置SearchableActivity等等。来看几个示例:
示例一:某分享
< meta-data
android:name="UMENG_APPKEY"
android:value="oooooooooooooxxxxxxxxxxxx" />
示例二:桌面快捷方式
< meta-data
android:name="android.app.shortcuts"
android:resource="@xml/shortcuts" />
示例三:18:9屏幕适配
< meta-data
android:name="android.max_aspect"
android:value="2.1" />
示例四:某地图
< meta-data
android:name="com.amap.api.v2.apikey"
android:value="oooooooooooooxxxxxxxxxxxx" />
我们接入某分享、某地图、其他私有第三方SDK时,一般都要先申请一个账号,用于接入配置。SDK则会在内部代码中读取这些数据,通过这些key标记来源的信息,分辨接入方,进行访问控制、数据统计等。
其实不知不觉之中,开发者接入了这些SDK,App运营中产生的一些数据也就分享给SDK开发商了,包括使用频率、用户画像等等。
我们在开发自己的SDK过程中,也可以使用这种方法控制访问。通过分配账号的方式要求接入方配置相关信息,并在SDK中读取配置好的< meta-data>信息,用于对比鉴权,若无相关匹配账号,则直接抛异常或者返回相关返回码。当然了,账号分配这一步也可以放到后台做,然而并不是所有的SDK接入都需要后台接入,比如分享SDK。