Gmail身份验证未返回应用程序

时间:2017-01-09 17:50:21

标签: ios swift firebase swift3 firebase-authentication

我已经使用Firebase实施了gmail登录,并且在按下已连接操作GIDSignIn.sharedInstance().signIn()的自定义按钮后,我成功地让用户验证了他的电子邮件。

但是,一旦用户允许基本个人资料访问,它就不会返回到应用程序,只会进入此屏幕:

login

在用户进行身份验证后,是否有人知道如何让它返回应用程序?这是我的控制台:

017-01-09 09:47:46.565367 Dog_Log[3922:829530] [MC] Reading from private effective user settings.
2017-01-09 09:47:53.702 Dog_Log[3922:] <FIRAnalytics/WARNING> Implementation of application:openURL:sourceApplication:annotation: not found. Please add the handler into your App Delegate. Class: Dog_Log.AppDelegate

1 个答案:

答案 0 :(得分:5)

<强>问题:

警告告诉您无法找到application(_:open:options:)的实施:

2017-01-09 09:47:53.702 Dog_Log[3922:] <FIRAnalytics/WARNING> Implementation of application:openURL:sourceApplication:annotation: not found. Please add the handler into your App Delegate. Class: Dog_Log.AppDelegate

<强>解决方案:

您可能忘记了要实现的application(_:open:options:)方法,并调用其中的handle(_:sourceApplication:annotation:),该方法处理重定向到您的应用程序。您的AppDelegate.swift应该如下所示(提示在代码注释中):

import UIKit
import Firebase
import GoogleSignIn

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

  var window: UIWindow?


  func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {

    // configure firebase
    FIRApp.configure()

    // configure google
    GIDSignIn.sharedInstance().clientID = FIRApp.defaultApp()?.options.clientID

    return true
  }

  func application(_ app: UIApplication, open url: URL, options: [UIApplicationOpenURLOptionsKey : Any] = [:]) -> Bool {

    // handled to go back to application after google log in
    let handled = GIDSignIn.sharedInstance().handle(url, sourceApplication:options[UIApplicationOpenURLOptionsKey.sourceApplication] as? String, annotation: [:])

    return handled
  }

  // other methods
}

您使用符合GIDSignInUIDelegate和GIDSignInDelegate的示例ViewController,以访问signIn方法并将其与自定义按钮的@IBAction一起使用:

import UIKit
import Firebase
import GoogleSignIn


class ViewController: UIViewController, GIDSignInUIDelegate, GIDSignInDelegate {

  override func viewDidLoad() {
    super.viewDidLoad()

    // make the view controller the delegate
    GIDSignIn.sharedInstance().uiDelegate = self
    GIDSignIn.sharedInstance().delegate = self
  }

  // your action of the button to call the signIn method
  @IBAction func pressGoogleSignInButton(_ sender: UIButton) {
    GIDSignIn.sharedInstance().signIn()
  }

  func sign(_ signIn: GIDSignIn!, didSignInFor user: GIDGoogleUser!, withError error: Error!) {
    if let error = error {
      print("failed to log into google: ", error)
      return
    }

    print("successfully logged into google ", user)

    guard let idToken = user.authentication.idToken else { return }
    guard let accessToken = user.authentication.accessToken else { return }
    let credentials = FIRGoogleAuthProvider.credential(withIDToken: idToken, accessToken: accessToken)

    FIRAuth.auth()?.signIn(with: credentials, completion: { (user, error) in
      if let error = error {
        print("Faild to create a firebase user with google account: ", error)
        return
      }

      guard let uid = user?.uid else { return }
      print("Successfully logged into firebase with google ", uid)
      // redirect to the next screen after successful login

    })
  }
}