Ошибка: ConnectionResult {statusCode = INTERNAL_ERROR, разрешение = null}

Я разрабатываю приложение, в котором я интегрирую Google Drive в свое приложение. Ниже мой код, который я просто скопировал из примера кода, но я получаю исключение при подключении с Google Диском.

Исключение: ConnectionResult{statusCode=INTERNAL_ERROR, resolution=null} в методе onConnectionFailed().

Пожалуйста, ребята поделитесь своими взглядами.

public class MainActivity extends Activity implements ConnectionCallbacks,
        OnConnectionFailedListener {

    private static final String TAG = "android-drive-quickstart";
    private static final int REQUEST_CODE_CAPTURE_IMAGE = 1;
    private static final int REQUEST_CODE_CREATOR = 2;
    private static final int REQUEST_CODE_RESOLUTION = 3;

    private GoogleApiClient mGoogleApiClient;
    private Bitmap mBitmapToSave;

    /**
     * Create a new file and save it to Drive.
     */
    private void saveFileToDrive() {
        // Start by creating a new contents, and setting a callback.
        Log.i(TAG, "Creating new contents.");
        final Bitmap image = mBitmapToSave;
        Drive.DriveApi.newContents(mGoogleApiClient).addResultCallback(new OnNewContentsCallback() {

            @Override
            public void onNewContents(ContentsResult result) {
                // If the operation was not successful, we cannot do anything
                // and must
                // fail.
                if (!result.getStatus().isSuccess()) {
                    Log.i(TAG, "Failed to create new contents.");
                    return;
                }
                // Otherwise, we can write our data to the new contents.
                Log.i(TAG, "New contents created.");
                // Get an output stream for the contents.
                OutputStream outputStream = result.getContents().getOutputStream();
                // Write the bitmap data from it.
                ByteArrayOutputStream bitmapStream = new ByteArrayOutputStream();
                image.compress(Bitmap.CompressFormat.PNG, 100, bitmapStream);
                try {
                    outputStream.write(bitmapStream.toByteArray());
                } catch (IOException e1) {
                    Log.i(TAG, "Unable to write file contents.");
                }
                // Create the initial metadata - MIME type and title.
                // Note that the user will be able to change the title later.
                MetadataChangeSet metadataChangeSet = new MetadataChangeSet.Builder()
                        .setMimeType("image/jpeg").setTitle("Android Photo.png").build();
                // Create an intent for the file chooser, and start it.
                IntentSender intentSender = Drive.DriveApi
                        .newCreateFileActivityBuilder()
                        .setInitialMetadata(metadataChangeSet)
                        .setInitialContents(result.getContents())
                        .build(mGoogleApiClient);
                try {
                    startIntentSenderForResult(
                            intentSender, REQUEST_CODE_CREATOR, null, 0, 0, 0);
                } catch (SendIntentException e) {
                    Log.i(TAG, "Failed to launch file chooser.");
                }
            }
        });
    }

    @Override
    protected void onResume() {
        super.onResume();
        if (mGoogleApiClient == null) {
            // Create the API client and bind it to an instance variable.
            // We use this instance as the callback for connection and connection
            // failures.
            // Since no account name is passed, the user is prompted to choose.
            mGoogleApiClient = new GoogleApiClient.Builder(this)
                    .addApi(Drive.API)
                    .addScope(Drive.SCOPE_FILE)
                    .addConnectionCallbacks(this)
                    .addOnConnectionFailedListener(this)
                    .build();
        }
        // Connect the client. Once connected, the camera is launched.
        mGoogleApiClient.connect();
    }

    @Override
    protected void onPause() {
        if (mGoogleApiClient != null) {
            mGoogleApiClient.disconnect();
        }
        super.onPause();
    }

    @Override
    protected void onActivityResult(final int requestCode, final int resultCode, final Intent data) {
        switch (requestCode) {
            case REQUEST_CODE_CAPTURE_IMAGE:
                // Called after a photo has been taken.
                if (resultCode == Activity.RESULT_OK) {
                    // Store the image data as a bitmap for writing later.
                    mBitmapToSave = (Bitmap) data.getExtras().get("data");
                }
                break;
            case REQUEST_CODE_CREATOR:
                // Called after a file is saved to Drive.
                if (resultCode == RESULT_OK) {
                    Log.i(TAG, "Image successfully saved.");
                    mBitmapToSave = null;
                    // Just start the camera again for another photo.
                    startActivityForResult(new Intent(MediaStore.ACTION_IMAGE_CAPTURE),
                            REQUEST_CODE_CAPTURE_IMAGE);
                }
                break;
        }
    }

    @Override
    public void onConnectionFailed(ConnectionResult result) {
        // Called whenever the API client fails to connect.
        Log.i(TAG, "GoogleApiClient connection failed: " + result.toString());
        if (!result.hasResolution()) {
            // show the localized error dialog.
            GooglePlayServicesUtil.getErrorDialog(result.getErrorCode(), this, 0).show();
            return;
        }
        // The failure has a resolution. Resolve it.
        // Called typically when the app is not yet authorized, and an
        // authorization
        // dialog is displayed to the user.
        try {
            result.startResolutionForResult(this, REQUEST_CODE_RESOLUTION);
        } catch (SendIntentException e) {
            Log.e(TAG, "Exception while starting resolution activity", e);
        }
    }

    @Override
    public void onConnected(Bundle connectionHint) {
        Log.i(TAG, "API client connected.");
        if (mBitmapToSave == null) {
            // This activity has no UI of its own. Just start the camera.
            startActivityForResult(new Intent(MediaStore.ACTION_IMAGE_CAPTURE),
                    REQUEST_CODE_CAPTURE_IMAGE);
            return;
        }
        saveFileToDrive();
    }

    @Override
    public void onDisconnected() {
        Log.i(TAG, "API client disconnected.");
    }

}

Ответы

Ответ 2

Heads up! В Консоли разработчиков есть проблема.

Если вы получаете эту ошибку даже после того, как 1) убедитесь, что вы зарегистрировали имя пакета с соответствующим отпечатком сертификата, и 2) (повторно), используя уже существующий проект, , затем следует проверить, что этот проект имеет имя продукта и адрес электронной почты (дважды проверьте, что он специально) связан с ним, оба находятся на экране согласия .

У очень старых проектов может не быть этих двух заполненных полей. В новых проектах эти поля заполняются некоторыми значениями по умолчанию.

Пришел мне день, чтобы найти это...

enter image description here

Ответ 3

Я разрешаю эту проблему, подписав приложение Google Диска на консоли API, выполнив следующие шаги.

  • Перейдите в Google Developers Console.
  • Выберите проект или создайте новый.
  • На боковой панели слева разверните API и авторизуйтесь. Затем щелкните API.
  • В списке API, убедитесь, что статус включен для API накопителя.
  • На боковой панели слева выберите "Учетные данные".

Если ваше приложение должно предоставить авторизованные запросы:

  • В разделе "OAuth" нажмите "Создать новый идентификатор клиента".
  • Выберите Установленное приложение и Android.
  • В поле Имя пакета введите имя пакета приложения Android.
  • Вставьте отпечаток SHA1 в запрошенную форму.
  • Нажмите "Создать идентификатор клиента".

Ответ 4

Для меня проблема заключалась в том, что когда в примере было:

.addApi(Drive.API)

И я не добавил диск api в консоль

это сообщение об ошибке помогло мне выяснить проблему

com.google.android.gms.drive.auth.c: Ошибка авторизации: сервер возвращенная ошибка: доступ не настроен. API не включен для вашего проекта, или существует ограничение на IP-адрес или каждый референт, настроенный на ваш ключ API и запрос не соответствуют этим ограничениям. пожалуйста используйте Google Developers Console для обновления конфигурации. См. https://developers.google.com/drive/handle-errors для деталей.

Ответ 5

Не забывайте разрешения:

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

Ответ 6

Есть ли у вас сообщения об ошибках в logcat? Наиболее вероятной причиной неудачного подключения является то, что вы неправильно настроили приложение в облачной консоли.

Смотрите инструкции здесь: https://developers.google.com/drive/android/auth

Ответ 7

В моем случае мне пришлось изменить идентификатор клиента, чтобы использовать точное имя пакета класса активности, создающего объект GoogleApiClient, а не пакет более высокого уровня.

Ответ 8

Я тоже получал ту же ошибку. Для моего проекта API-интерфейс Drive API не был включен в API и auth → API. После включения этого Drive API эта проблема была решена.

Ответ 9

Я решил добавить эту строку к gradle:

compile 'com.google.android.gms:play-services-identity:8.1.0'

Ответ 10

Вам нужно иметь два отдельных идентификатора клиента, один для отладки, другой для выпуска. Иногда мы пропускаем очевидное.

Ответ 11

В Android Studio перейдите в

Инструмент- > Android-SDK Manager → Служба Google Play

Обновите Службу Google Play.. Я уверен, что она будет работать

Ответ 12

У меня была та же проблема, что и выше, когда я переместил существующее приложение из Eclipse в студию Android. Моя проблема заключалась в том, что я назвал applicationId отличным от идентификатора пакета. Изменение приложения должно быть таким же, как имя пакета, решило проблему.

Ответ 13

У меня та же проблема. Мой вход работал, но внезапно перестал работать. Я перепробовал все решения, упомянутые здесь. Но не решил мою проблему. Тем не менее, после отключения входа в Google и включения он решил мою проблему. Поэтому просто перейдите в консоль Firebase и выберите Аутентификация > Методы входа > google > нажмите Изменить > отключить и включить.