在清单的应用程序标记中缺少名为“com.google.android.gms.appstate.APP_ID”的元数据标记

时间:2014-03-29 21:47:07

标签: android google-play-services google-play-games google-login


NUM_OF_TRIES_TO_FIX_THIS = 12; //我正在计算apk的

所以我们遇到了一个大问题,我们距离发布我们的应用只有两步之遥,但我们无法在我们的应用中实施Google Play服务。 它在日志中不断告诉我们:

03-29 22:36:21.709: E/ValidateServiceOp(9477): Using Google Play games services requires a     metadata tag with the name "com.google.android.gms.games.APP_ID" in the application tag of your manifest
03-29 22:36:21.729: E/ValidateServiceOp(9477): Missing metadata tag with the name "com.google.android.gms.appstate.APP_ID" in the application tag of your manifest.
03-29 22:36:21.809: E/ValidateServiceOp(9477): Using Google Play games services requires a metadata tag with the name "com.google.android.gms.games.APP_ID" in the application tag of your manifest
03-29 22:36:21.969: E/AndroidRuntime(13931): FATAL EXCEPTION: main
03-29 22:36:21.969: E/AndroidRuntime(13931): java.lang.IllegalStateException: A fatal developer error has occurred. Check the logs for further information.
03-29 22:36:21.969: E/AndroidRuntime(13931):    at com.google.android.gms.internal.eh$h.b(Unknown Source)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at com.google.android.gms.internal.eh$h.a(Unknown Source)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at com.google.android.gms.internal.eh$b.ec(Unknown Source)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at com.google.android.gms.internal.eh$a.handleMessage(Unknown Source)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at android.os.Handler.dispatchMessage(Handler.java:99)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at android.os.Looper.loop(Looper.java:137)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at android.app.ActivityThread.main(ActivityThread.java:4960)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at java.lang.reflect.Method.invokeNative(Native Method)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at java.lang.reflect.Method.invoke(Method.java:511)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
03-29 22:36:21.969: E/AndroidRuntime(13931):    at dalvik.system.NativeStart.main(Native Method)

但我们的清单中有id!

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.uraniumdevelopers.etchcubes"
    android:versionCode="6"
    android:versionName="0.4" >

    <uses-sdk
        android:minSdkVersion="14"
        android:targetSdkVersion="19" />

    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <meta-data
            android:name="com.google.android.gms.version"
            android:value="@integer/google_play_services_version" />
        <meta-data
            android:name="com.google.android.gms.appstate.APP_ID"
            android:value="457870338644" />
        <meta-data
            android:name="com.google.android.gms.games.APP_ID"
            android:value="457870338644" />
        <activity
            android:name="com.uraniumdevelopers.etchcubes.MainActivity"
            android:label="@string/app_name"
            android:theme="@android:style/Theme.NoTitleBar.Fullscreen" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

服务的初始化如下:

    GoogleApiClient.Builder builder = new GoogleApiClient.Builder(
            getBaseContext());
    builder.addApi(Games.API).addApi(Plus.API).addApi(AppStateManager.API)
            .addScope(Games.SCOPE_GAMES).addScope(Plus.SCOPE_PLUS_LOGIN)
            .addScope(AppStateManager.SCOPE_APP_STATE).setViewForPopups(rl);
    mClient = builder.build();

我们非常感谢您的帮助!

2 个答案:

答案 0 :(得分:2)

替换4 - &gt; \ u0034 例如

<meta-data android:name="com.google.android.gms.games.APP_ID" android:value="\u003457870338644" />

访问 http://developer.android.com/guide/topics/manifest/meta-data-element.html

答案 1 :(得分:0)

尝试在strings.xml中添加app_id,并在清单文件中提及该ID。

有关详细信息,请查看此答案。重要的是答案中的评论。 Fatal exception in playservices