AWS Amplify Google 身份验证用户未重定向回

AWS Amplify Google auth user not redirected back

我正在尝试使用 AWS Amplify 在 React 本机应用程序中实施 Google 身份验证。我已经在我的应用程序中安装了 Amplify,还安装了 Auth。

我在 Google api 中有这个客户端:

授权javascript来源:

https://inventory053721f5-053721f5-develop.auth.eu-west-1.amazoncognito.com

授权的重定向 uri:

https://inventory053721f5-053721f5-develop.auth.eu-west-1.amazoncognito.com/oauth2/idpresponse

aws-exports.js:

// WARNING: DO NOT EDIT. This file is automatically generated by AWS Amplify. It will be overwritten.

const awsmobile = {
    "aws_project_region": "eu-west-1",
    "aws_cognito_identity_pool_id": "***",
    "aws_cognito_region": "eu-west-1",
    "aws_user_pools_id": "***",
    "aws_user_pools_web_client_id": "***",
    "oauth": {
        "domain": "***",
        "scope": [
            "phone",
            "email",
            "openid",
            "profile",
            "aws.cognito.signin.user.admin"
        ],
        "redirectSignIn": "inventory://",
        "redirectSignOut": "inventory://",
        "responseType": "code"
    },
    "federationTarget": "COGNITO_USER_POOLS"
};


export default awsmobile;

我的 App.tsx 看起来像这样:

import React, {FunctionComponent} from 'react';
import Amplify, {Auth} from 'aws-amplify';
import {Button} from 'react-native';
import config from '../../aws-exports';

Amplify.configure(config);

export interface AppProps {}

const App: FunctionComponent<AppProps> = () => {
  return <Button title={'Login'} onPress={() => Auth.federatedSignIn()} />;
};

export default App;

发生了什么的视频:

https://imgur.com/tPEcoop

设置 Amplify Auth 并配置您的 social provider, you also have to set up linking 以便您的应用程序可以处理从网络浏览器返回到您的应用程序的回调:

  1. 记下您在 运行 amplify add auth(例如 myapp:\)时为 'redirect signin uri' 输入的值。
  2. 对于在 iOS 上使用 react-native-cli(而不是 Expo)制作的应用程序,打开 Xcode 项目(在 ios 文件夹中,rnamplify.xcworkspace) .然后打开info.plist作为源码,添加以下内容:
<key>CFBundleURLTypes</key>
<array>
  <dict>
    <key>CFBundleURLSchemes</key>
    <array>
      <string>myapp</string>
    </array>
  <dict>
</array>
  1. 对于在 Android 上使用 react-native-cli(而不是 Expo)制作的应用程序,在 Android Studio 中打开 android/app/main/AndroidManifest.xml 并添加以下内容 intent-filter:
<intent-filter android:label="filter_react_native">
  <action android:name="android.intent.action.VIEW" />
  <category android:name="android.intent.category.DEFAULT" />
  <category android:name="android.intent.category.BROWSABLE" />
  <data android:scheme="myapp" />
</intent-filter>

如果您的应用是使用 Expo 而不是 react-native-cli 制作的,那么您就不会执行上面的步骤 2 和 3。相反,打开 app.json 文件并将 scheme 键值对添加到 "expo" 属性:

{
  "expo": {
   "scheme": "myapp"
  }
}

虽然这可能不完全是您的情况。如果您使用的是 amplify CLI,请确保您的重定向登录和注销 URI 设置正确。

您可以通过 运行 amplify update auth

进行调整