G +连接失败statusCode = SIGN_IN_REQUIRED

时间:2016-10-04 15:35:47

标签: android google-drive-api google-plus

为什么我收到此错误?我已经在Google Developer Console中创建了一个项目,启用了Drive API和Google+ API,并添加了“Android Client Id”和我签名的apk的sha1(顺便说一句,我已经在Google Play控制台上分享了测试版)。

我获得权限 GET_ACCOUNTS ,当我在列表中选择我的G +邮件时,我收到此错误:

 D/G+: Connection failed4ConnectionResult{statusCode=SIGN_IN_REQUIRED, resolution=PendingIntent

我是否必须在项目文件夹中的某处添加 client_id.json ? (我刚刚在Google Developer Console中为Drive API创建了它。)

代码:

      // initialize g+ api client
    if (Sp.getBoolean("plus_pic", false)) {

        mGoogleApiClient = new GoogleApiClient.Builder(this)
                .addConnectionCallbacks(this)
                .addOnConnectionFailedListener(this)
                .addApi(Drive.API)
                .addScope(Drive.SCOPE_FILE)
                .build();
    }

 @Override
public void onConnected(Bundle bundle) {

    if (Plus.PeopleApi.getCurrentPerson(mGoogleApiClient) != null) {
        Person currentPerson = Plus.PeopleApi.getCurrentPerson(mGoogleApiClient);

        String accountName = Plus.AccountApi.getAccountName(mGoogleApiClient);
        Person.Image personImage;
        Person.Cover.CoverPhoto personCover;

        try {

            personImage = currentPerson.getImage();
            personCover = currentPerson.getCover().getCoverPhoto();
        } catch (Exception e) {
            Log.e("G+ COnnection error"," ->"+e.toString());
            personCover = null;
            personImage = null;
        }

        if (personCover != null && personImage != null) {

            String imgUrl = personImage.getUrl();
            Log.e("g+ connection","cover and pic not null");
            // getting full size image
            StringBuilder stringBuilder = new StringBuilder();
            stringBuilder.append(imgUrl);
            stringBuilder.delete(imgUrl.length() - 6, imgUrl.length());
            Log.d("G+", stringBuilder.toString());
            mGoogleName.setText(currentPerson.getDisplayName());
            mGoogleId.setText(accountName);
            // setting cover pic
            ImageLoader.getInstance().loadImage(personCover.getUrl(), displayImageOptions, new SimpleImageLoadingListener() {
                @Override
                public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
                    super.onLoadingComplete(imageUri, view, loadedImage);
                    drawerHeaderParent.setBackgroundColor(Color.parseColor("#ffffff"));
                    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
                        drawerHeaderView.setBackground(new BitmapDrawable(loadedImage));
                    } else
                        drawerHeaderView.setBackgroundDrawable(new BitmapDrawable(loadedImage));

                }

                @Override
                public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
                    super.onLoadingFailed(imageUri, view, failReason);
                    drawerHeaderView.setBackgroundResource(R.drawable.app_header);
                    drawerHeaderParent.setBackgroundColor(Color.parseColor((currentTab == 1 ? skinTwo : skin)));
                }

                @Override
                public void onLoadingStarted(String imageUri, View view) {
                    super.onLoadingStarted(imageUri, view);
                    drawerHeaderView.setBackgroundResource(R.drawable.app_header);
                    drawerHeaderParent.setBackgroundColor(Color.parseColor((currentTab == 1 ? skinTwo : skin)));
                }
            });

            // setting profile pic
            ImageLoader.getInstance().loadImage(stringBuilder.toString(), displayImageOptions, new SimpleImageLoadingListener() {
                @Override
                public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
                    super.onLoadingComplete(imageUri, view, loadedImage);
                    drawerProfilePic.setImageBitmap(loadedImage);
                    drawerProfilePic.setVisibility(View.VISIBLE);
                }

                @Override
                public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
                    super.onLoadingFailed(imageUri, view, failReason);
                }
            });


        } else {
            Toast.makeText(this, getResources().getText(R.string.no_cover_photo), Toast.LENGTH_SHORT).show();
            drawerHeaderView.setBackgroundResource(R.drawable.app_header);
            drawerHeaderParent.setBackgroundColor(Color.parseColor((currentTab == 1 ? skinTwo : skin)));
        }
    }
}

@Override
public void onConnectionSuspended(int i) {

    Log.d("G+", "Connection suspended");
    new Thread(new Runnable() {
        @Override
        public void run() {
            if (mGoogleApiClient != null) {

                mGoogleApiClient.connect();
            }
        }
    }).run();
}

public void onConnectionFailed(final ConnectionResult result) {
    Log.d("G+", "Connection failed"+ result.getErrorCode()+result.toString());

    if (!mIntentInProgress && result.hasResolution()) {
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    mIntentInProgress = true;
                    startIntentSenderForResult(result.getResolution().getIntentSender(),
                            RC_SIGN_IN, null, 0, 0, 0);
                } catch (IntentSender.SendIntentException e) {
                    // The intent was canceled before it was sent.  Return to the default
                    // state and attempt to connect to get an updated ConnectionResult.
                    mIntentInProgress = false;
                    if (mGoogleApiClient != null) {

                        mGoogleApiClient.connect();
                    }
                }
            }
        }).run();
    }
}

protected void onActivityResult(int requestCode, int responseCode, Intent intent) {
    if (requestCode == RC_SIGN_IN && !mGoogleApiKey && mGoogleApiClient != null) {
        new Thread(new Runnable() {
            @Override
            public void run() {
                mIntentInProgress = false;
                mGoogleApiKey = true;
                // !mGoogleApiClient.isConnecting
                if (mGoogleApiClient.isConnecting()) {
                    mGoogleApiClient.connect();
                } else
                    mGoogleApiClient.disconnect();

            }
        }).run();
    }

2 个答案:

答案 0 :(得分:1)

您收到错误SIGN_IN_REQUIRED,因为客户端尝试连接到该服务但该用户未登录。

  

客户可以选择在不使用API​​的情况下继续。或者,如果hasResolution()返回true,则客户端可以调用[startResolutionForResult(Activity, int)](https://developers.google.com/android/reference/com/google/android/gms/common/ConnectionResult.html#startResolutionForResult(android.app.Activity,int))来提示用户登录。登录活动返回后{{3}进一步的尝试应该成功。

根据此RESULT_OK,尝试通过从您的Gmail帐户转到Google API控制台来解决此问题。在那里,您会看到Google Drive API前面的停用按钮。您将看到一个齿轮或设置按钮,单击它并生成oAuth令牌。

以下是一些相关主题:

希望这有帮助!

答案 1 :(得分:0)

在我的原因中,我错误地使用了释放SHA1密钥来在开发者控制台中生成API。然后使用debug.keystore创建SHA1密钥并在我的api凭据中更新。它开始工作了。

keytool -list -v -keystore "C:\Users\<user>n\.android\debug.keystore" -alias androiddebugkey -storepass andro
id -keypass android