1

Google Backup API について勉強していた Android アプリケーションを開発しています。このチュートリアル http://www.edumobile.org/android/android-development/backup-manager/を読みました。

実装しようとしましたが、常にクラッシュしています

ログキャットは

07-31 13:39:35.797: E/AndroidRuntime(18279): FATAL EXCEPTION: main
07-31 13:39:35.797: E/AndroidRuntime(18279): java.lang.IllegalStateException: Could not execute method of the activity
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.view.View$1.onClick(View.java:2072)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.view.View.performClick(View.java:2408)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.view.View$PerformClick.run(View.java:8816)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.os.Handler.handleCallback(Handler.java:587)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.os.Handler.dispatchMessage(Handler.java:92)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.os.Looper.loop(Looper.java:123)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.app.ActivityThread.main(ActivityThread.java:4633)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at java.lang.reflect.Method.invokeNative(Native Method)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at java.lang.reflect.Method.invoke(Method.java:521)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at dalvik.system.NativeStart.main(Native Method)
07-31 13:39:35.797: E/AndroidRuntime(18279): Caused by: java.lang.reflect.InvocationTargetException
07-31 13:39:35.797: E/AndroidRuntime(18279):    at com.pref.BackupManagerExample.onRestoreButtonClick(BackupManagerExample.java:164)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at java.lang.reflect.Method.invokeNative(Native Method)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at java.lang.reflect.Method.invoke(Method.java:521)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.view.View$1.onClick(View.java:2067)
07-31 13:39:35.797: E/AndroidRuntime(18279):    ... 11 more
07-31 13:39:35.797: E/AndroidRuntime(18279): Caused by: java.lang.SecurityException: getCurrentTransport: Neither user 10066 nor current process has android.permission.BACKUP.
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.os.Parcel.readException(Parcel.java:1247)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.os.Parcel.readException(Parcel.java:1235)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.app.backup.IBackupManager$Stub$Proxy.getCurrentTransport(IBackupManager.java:444)
07-31 13:39:35.797: E/AndroidRuntime(18279):    at android.app.backup.BackupManager.requestRestore(BackupManager.java:141)
07-31 13:39:35.797: E/AndroidRuntime(18279):    ... 15 more

そして最も顕著なのは

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

    <uses-sdk android:minSdkVersion="8" />
    <uses-permission android:name="android.permission.INTERNET"/>

<uses-permission android:name="android.permission.BACKUP" />
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" 
         android:theme="@android:style/Theme.NoTitleBar.Fullscreen"
         android:backupAgent="com.pref.BackupManagerExample">
         <activity android:name=".Preff" />



        <activity
            android:name=".PrefrencesActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />

            </intent-filter>
        </activity>


         <meta-data android:name="com.google.android.backup.api_key"
    android:value="AEdPqrEAAAAIo8gaMLEy1sb1bVd6Cyqs5dxPAy8qvFzfILeLWB" />
         <activity
            android:name=".BackupManagerExample"
            android:enabled="true"/>

    </application>

</manifest>

エラーはこちら

 Resotre.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                try {
                    // TODO Auto-generated method stub

// この行はエラーを示しています

 mBackupManager.requestRestore(
                                    new RestoreObserver() {
                                        public void restoreFinished(int error) {
                                            Log.v(TAG, "Restore finished, error = " + error);
                                            populateUI();
                                        }
                                    }
                            );
                    } catch (Exception e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
            });

このエラーの原因は何ですか? どうすれば削除できますか?

編集

これは古いものではありませんが、このコードも使用しました。

https://github.com/StylingAndroid/BackupRestore

バックアップ API がどのように機能するかを確認するだけで、これも同じエラーが発生しました。

07-31 18:10:33.226: E/AndroidRuntime(20664): Caused by: java.lang.SecurityException: getCurrentTransport: Neither user 10072 nor current process has android.permission.BACKUP.

ここから私は読む

http://developer.android.com/guide/topics/data/backup.html

データのバックアップは、すべての Android 搭載デバイスで利用できるとは限りません。ただし、デバイスがバックアップ トランスポートを提供しない場合でも、アプリケーションは悪影響を受けません。

私が使用しているデバイスは、サムスンのギャラクシー ポップです。

4

1 に答える 1

1

BackupManager を直接使用しようとしていますが、android.permission.BACKUP 権限がないと使用できません。この権限は、プラットフォーム キーで署名されたアプリ (基本的にはシステム アプリ) にのみ付与されます。

マニフェストでアクセス許可を要求していますが、インストール中にログを見ると、アプリに対して "アクセス許可を付与していません" という警告が表示されるはずです。

したがって、コードは一般的に正しいように見えますが、保護されたメソッドを呼び出そうとするとセキュリティ例外が発生します。

于 2012-09-27T00:45:22.047 に答える