如何访问 AndroidManifest.xml 文件中的 BuildConfig 值?

问题描述 投票:0回答:7

是否可以从 AndroidManifest.xml 访问 BuildConfig 值?

在我的 build.gradle 文件中,我有:

defaultConfig {
    applicationId "com.compagny.product"
    minSdkVersion 16
    targetSdkVersion 21
    versionCode 1
    versionName "1.0"

    // Facebook app id
    buildConfigField "long", "FACEBOOK_APP_ID", FACEBOOK_APP_ID
}

FACEBOOK_APP_ID
在我的 gradle.properties 文件中定义:

# Facebook identifier (app ID)
FACEBOOK_APP_ID=XXXXXXXXXX

要在我的应用程序中使用 Facebook connect,我必须将此行添加到我的 AndroidManifest.xml 中:

<meta-data android:name="com.facebook.sdk.ApplicationId" android:value="@string/applicationId"/> 

我想用gradle中定义的BuildConfig字段

@string/applicationId
替换
FACEBOOK_APP_ID
,如下所示:

<meta-data android:name="com.facebook.sdk.ApplicationId" android:value="FACEBOOK_APP_ID"/> 

使用 BuildConfig 可以吗?如果没有,我怎样才能实现这个目标?

android android-gradle-plugin android-xml android-facebook
7个回答
237
投票

更换

buildConfigField "long", "FACEBOOK_APP_ID", FACEBOOK_APP_ID

resValue "string", "FACEBOOK_APP_ID", FACEBOOK_APP_ID

然后 重建您的项目(Android Studio -> 构建 -> 重建项目)。

这两个命令都会在项目构建期间生成生成的值 - 第一种情况下由 Java 常量组成,第二种情况下由 Android 资源组成,但第二种方法将生成一个

string
资源值,可以使用
@string/FACEBOOK_APP_ID
访问该值句法。这意味着它可以在清单和代码中使用。


100
投票

从 AndroidManifest.xml 访问 Gradle Build Config 值的另一种方法是通过如下占位符:

android {
    defaultConfig {
        manifestPlaceholders = [ facebookAppId:"someId..."]
    }
    productFlavors {
        flavor1 {
        }
        flavor2 {
            manifestPlaceholders = [ facebookAppId:"anotherId..." ]
        }
    }
}

然后在你的清单中:

<meta-data android:name="com.facebook.sdk.ApplicationId" android:value="${facebookAppId}"/> 

在此处查看更多详细信息:https://developer.android.com/studio/build/manifest-build-variables.html

(旧链接仅供参考:http://tools.android.com/tech-docs/new-build-system/user-guide/manifest-merger


60
投票

注意:当您使用

resValue
时,该值可能会意外地被字符串资源文件覆盖(例如,对于另一种语言)

要获得可在清单和 java 代码中使用的真正常量值,请同时使用

manifestPlaceholders
buildConfigField
:例如

android {
    defaultConfig {
        def addConstant = {constantName, constantValue ->
            manifestPlaceholders += [ (constantName):constantValue]
            buildConfigField "String", "${constantName}", "\"${constantValue}\""
        }

        addConstant("FACEBOOK_APP_ID", "xxxxx")
    }

在清单文件中访问:

<meta-data android:name="com.facebook.sdk.ApplicationId" android:value="${FACEBOOK_APP_ID}"/>

来自java:

BuildConfig.FACEBOOK_APP_ID

如果常量值需要特定于 buildType,则需要调整助手

addConstant
(以使用常规闭包语义),例如

buildTypes {
    def addConstantTo = {target, constantName, constantValue ->
        target.manifestPlaceholders += [ (constantName):constantValue]
        target.buildConfigField "String", "${constantName}", "\"${constantValue}\""
    }
    debug {
        addConstantTo(owner,"FACEBOOK_APP_ID", "xxxxx-debug")
    }
    release {
        addConstantTo(owner,"FACEBOOK_APP_ID", "xxxxx-release")
    }

6
投票

访问清单中的 build.gradle 属性,如下例所示:

例如,您的 build.gradle 中有一个属性“applicationId”,并且您想在 AndroidManifest 中访问该属性:

在AndroidManifest中访问“applicationId”:

<receiver
        android:name="com.google.android.gms.gcm.GcmReceiver"
        android:exported="true"
        android:permission="com.google.android.c2dm.permission.SEND">
        <intent-filter>
            <action android:name="com.google.android.c2dm.intent.RECEIVE" />
            <category android:name="${applicationId}" />
        </intent-filter>
    </receiver>

类似地,我们可以为其他常量创建字符串资源并在代码文件中访问它们,就像这样简单:

context.getString(R.string.GCM_SENDER_ID);

3
投票

@stkent 很好,但忘记添加您需要随后重建项目

更换

buildConfigField "long", "FACEBOOK_APP_ID", FACEBOOK_APP_ID

resValue "string", "FACEBOOK_APP_ID", FACEBOOK_APP_ID

然后

Android Studio -> Build -> Rebuild Project

这将允许 android 生成可通过

访问的字符串资源
R.string.FACEBOOK_APP_ID

1
投票

另一个选项:使用不同的字符串资源文件来替换所有与 Flavor 相关的值:

第1步: 在“src”文件夹中创建一个新文件夹,并命名为您的风味名称,我的例子是“stage”

第2步: 为所有依赖于风味的文件创建资源文件 例如:

第3步: 我还使用不同的图标,因此您也会看到 mipmap 文件夹。对于这个问题,只有“strings.xml”很重要。现在您可以覆盖所有重要的字符串资源。您只需要包含您想要覆盖的那些,所有其他将从主“strings.xml”中使用,它将显示在 Android Studio 中,如下所示:

第四步: 使用项目中的字符串资源并放松:


0
投票

您可以使用如下长值

buildConfigField 'long', 'FLAVOR_LONG', '11500L'
© www.soinside.com 2019 - 2024. All rights reserved.