我正在使用this指南在Xamarin中使用地图。
它说我应该使用密钥的不同值
<meta-data android:name="com.google.android.maps.v2.API_KEY"
android:value="AbCdEfGhIjKlMnOpQrStUvWValueGoesHere" />
用于调试和发布版本;调试版本应使用包含来自debug.keystore
的SHA-1证书的API密钥,该证书具有众所周知的默认密码。
在实时模式下,我应该使用自定义密钥库文件中的SHA-1证书,我知道密码的密码。实时API密钥和SHA-1证书在实时APK中工作,但不在调试版本中工作。我猜这是有道理的。我应该有一个用于调试的Google Android API密钥,还有一个用于生产。
我不想做的是在我的AndroidManifest.xml
文件中有这个:
<meta-data android:name="com.google.android.maps.v2.API_KEY"
android:value="<My Debug API Key>" />
<!--<meta-data android:name="com.google.android.maps.v2.API_KEY"
android:value="<My Release API Key>" />-->
...根据我是在进行调试还是发布版本来更改注释掉的部分。有没有更有效的方法来执行此操作(类似于ASP.NET应用程序中的配置转换)?
我已经做了一些搜索,并且有一些自动应用的调试覆盖,但似乎我对该过程没有很大的控制权。
答案 0 :(得分:2)
您可以使用汇编级MetaData
属性在Manifest的Application元素中定义标记,并使用条件编译:
#if DEBUG
[assembly: MetaData("com.google.android.maps.v2.API_KEY", Value = "DebugKEYValue")]
#else
[assembly: MetaData("com.google.android.maps.v2.API_KEY", Value = "ReleaseKEYValue")]
#endif
根据构建类型,这将导致:
<application android:allowBackup="true" android:icon="@mipmap/icon" android:label="@string/app_name" android:name="android.app.Application" android:debuggable="true">
<meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="DebugValue" />
或者:
<application android:allowBackup="true" android:icon="@mipmap/icon" android:label="@string/app_name" android:name="android.app.Application">
<meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="ReleaseKEYValue" />