Google Play服务更新到版本13后,我收到了错误消息

时间:2013-11-01 09:13:24

标签: java android google-play-services

如何解决此错误?

  

引起:java.lang.illegalargumentexception   11-01 11:08:12.845:E / AndroidRuntime(28885):引起:java.lang.IllegalStateException:应用程序的AndroidManifest.xml中的元数据标签没有正确的值。预期4030500但找到0.您必须在元素中包含以下声明:


google-play-services_lib清单:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.google.android.gms"
    android:versionCode="4030530"
    android:versionName="4.0.30 (889083-30)" >

    <uses-sdk android:minSdkVersion="8"/>

</manifest>


public void loginGooglePlus() {
    aHelper.setup(this, GameHelper.CLIENT_APPSTATE | GameHelper.CLIENT_GAMES);
    mHelper = aHelper.getAppStateClient();
    //crash is here
    mHelper.connect();
}


完整错误日志:

11-01 11:38:13.507: E/AndroidRuntime(31297): FATAL EXCEPTION: main
11-01 11:38:13.507: E/AndroidRuntime(31297): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.company.application.android.aja/com.company.application.android.aja.BeetleBattleAndroidActivity}: java.lang.IllegalStateException: The meta-data tag in your app's AndroidManifest.xml does not have the right value.  Expected 4030500 but found 0.  You must have the following declaration within the <application> element:     <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2077)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2104)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.ActivityThread.access$600(ActivityThread.java:134)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1247)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.os.Handler.dispatchMessage(Handler.java:99)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.os.Looper.loop(Looper.java:154)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.ActivityThread.main(ActivityThread.java:4624)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at java.lang.reflect.Method.invokeNative(Native Method)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at java.lang.reflect.Method.invoke(Method.java:511)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:965)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:732)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at dalvik.system.NativeStart.main(Native Method)
11-01 11:38:13.507: E/AndroidRuntime(31297): Caused by: java.lang.IllegalStateException: The meta-data tag in your app's AndroidManifest.xml does not have the right value.  Expected 4030500 but found 0.  You must have the following declaration within the <application> element:     <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.google.android.gms.common.GooglePlayServicesUtil.n(Unknown Source)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(Unknown Source)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.google.android.gms.internal.de.connect(Unknown Source)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.google.android.gms.appstate.AppStateClient.connect(Unknown Source)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.company.application.android.aja.BeetleBattleAndroidActivity.loginGooglePlus(BeetleBattleAndroidActivity.java:153)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at com.company.application.android.aja.BeetleBattleAndroidActivity.onCreate(BeetleBattleAndroidActivity.java:143)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.Activity.performCreate(Activity.java:4509)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1050)
11-01 11:38:13.507: E/AndroidRuntime(31297):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2041)
11-01 11:38:13.507: E/AndroidRuntime(31297):    ... 11 more

8 个答案:

答案 0 :(得分:154)

您需要在清单中添加以下内容:

<application>
    <meta-data 
       android:name="com.google.android.gms.version" 
       android:value="@integer/google_play_services_version" />
    ...
</application>

编辑:

此信息可在logcat错误消息以及Setting Up Google Play Services (感谢Brais Gabin)

中找到

答案 1 :(得分:23)

@ Benoit'a答案有确切的解决方案我正在回答其他知识:

1。 Benoit回答的一种方式是添加AndroidManifest.xml

的应用内标记
<meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />

2. 我们可以直接添加像

这样的版本代码
<meta-data android:name="com.google.android.gms.version" android:value="4030500" />

4030500是版本代码,存储在

<强>谷歌播放services_lib&GT; RES&GT;值&GT; version.xml

<integer name="google_play_services_version">4030500</integer>

结论:最新的Google Play服务需要一个版本名称,使用<meta-data .. />内的AndroidManifest.xml来提及

注意: 我强烈建议使用第一种

答案 2 :(得分:4)

自从你提出这个问题后,有些事情发生了变化。如果您使用的是Google Play服务7.0或更新版本,Gradle会自动合并清单并为您提供所需的元数据。

引用Ian Lake

  

(...)Google Play服务   如果您使用Gradle,7.0还有另一个节省时间的功能:它会自动包含

<meta-data android:name="com.google.android.gms.version"
           android:value="@integer/google_play_services_version"/>
  在您的AndroidManifest.xml中输入

- 无需手动添加   它!简单清单合并库的简单例子   添加所需的元数据,接收器,权限以及其他任何内容   有需要 - 少忘记一件事!

     

注意:这不适用于完整的播放服务或   play-services-all-wear AARs - 只有粒度AAR才能构建   英寸

答案 3 :(得分:2)

确保将以下两个元数据标记添加到“您的”应用程序的AndroidManifest.xml

<meta-data 
            android:name="com.google.android.maps.v2.API_KEY"
            android:value="YOUR_API_KEY"/>
<meta-data 
            android:name="com.google.android.gms.version"
            android:value="@integer/google_play_services_version"/>

这个解决方案对我有用。

答案 4 :(得分:2)

我将现有项目从Eclipse导入Android Studio,在Eclipse项目中Integers.xml包含硬编码值,如下所示

<integer name="google_play_services_version">5089000</integer>

导致版本与Android Studio构建的最新版Play服务冲突。从Integers.xml删除此行后,它开始为我工作。

答案 5 :(得分:1)

我确实在所包含的google服务副本的res / values文件夹中创建了一个文件“version.xml”并粘贴了代码:

<?xml version="1.0" encoding="UTF-8"?>
<resources>
<integer name="google_play_services_version">4030500</integer>
</resources>

原始副本错过了文件,它确实解决了我的问题

答案 6 :(得分:1)

如果仍然有错误,请尝试此操作。

对我有用

for(String i: new ArrayList<>(list_old)) {
                for(String j: new ArrayList<>(list_new)) {
                    if (!i.equals(j)) {
                        list_old.add(i);
                        break;
                    }
                }
            }

答案 7 :(得分:-1)

关闭<meta-data>代码后添加<application>。这解决了我的问题