Ответ 1
Я решил проблему зарегистрировать приложение и создать подпись отпечатка сертификата подписки.
Я следил за ссылками и решил мою проблему.
Я разрабатываю приложение, в котором я интегрирую 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.");
}
}
Я решил проблему зарегистрировать приложение и создать подпись отпечатка сертификата подписки.
Я следил за ссылками и решил мою проблему.
Heads up! В Консоли разработчиков есть проблема.
Если вы получаете эту ошибку даже после того, как 1) убедитесь, что вы зарегистрировали имя пакета с соответствующим отпечатком сертификата, и 2) (повторно), используя уже существующий проект, , затем следует проверить, что этот проект имеет имя продукта и адрес электронной почты (дважды проверьте, что он специально) связан с ним, оба находятся на экране согласия .
У очень старых проектов может не быть этих двух заполненных полей. В новых проектах эти поля заполняются некоторыми значениями по умолчанию.
Пришел мне день, чтобы найти это...
Я разрешаю эту проблему, подписав приложение Google Диска на консоли API, выполнив следующие шаги.
Если ваше приложение должно предоставить авторизованные запросы:
Для меня проблема заключалась в том, что когда в примере было:
.addApi(Drive.API)
И я не добавил диск api в консоль
это сообщение об ошибке помогло мне выяснить проблему
com.google.android.gms.drive.auth.c: Ошибка авторизации: сервер возвращенная ошибка: доступ не настроен. API не включен для вашего проекта, или существует ограничение на IP-адрес или каждый референт, настроенный на ваш ключ API и запрос не соответствуют этим ограничениям. пожалуйста используйте Google Developers Console для обновления конфигурации. См. https://developers.google.com/drive/handle-errors для деталей.
Не забывайте разрешения:
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
Есть ли у вас сообщения об ошибках в logcat? Наиболее вероятной причиной неудачного подключения является то, что вы неправильно настроили приложение в облачной консоли.
Смотрите инструкции здесь: https://developers.google.com/drive/android/auth
В моем случае мне пришлось изменить идентификатор клиента, чтобы использовать точное имя пакета класса активности, создающего объект GoogleApiClient, а не пакет более высокого уровня.
Я тоже получал ту же ошибку. Для моего проекта API-интерфейс Drive API не был включен в API и auth → API. После включения этого Drive API эта проблема была решена.
Я решил добавить эту строку к gradle:
compile 'com.google.android.gms:play-services-identity:8.1.0'
Вам нужно иметь два отдельных идентификатора клиента, один для отладки, другой для выпуска. Иногда мы пропускаем очевидное.
В Android Studio перейдите в
Инструмент- > Android-SDK Manager → Служба Google Play
Обновите Службу Google Play.. Я уверен, что она будет работать
У меня была та же проблема, что и выше, когда я переместил существующее приложение из Eclipse в студию Android. Моя проблема заключалась в том, что я назвал applicationId отличным от идентификатора пакета. Изменение приложения должно быть таким же, как имя пакета, решило проблему.
У меня та же проблема. Мой вход работал, но внезапно перестал работать. Я перепробовал все решения, упомянутые здесь. Но не решил мою проблему. Тем не менее, после отключения входа в Google и включения он решил мою проблему. Поэтому просто перейдите в консоль Firebase и выберите Аутентификация > Методы входа > google > нажмите Изменить > отключить и включить.