在 iOS 上使用 Twitter 登录服务进行身份验证

您可以将 Twitter 身份验证机制集成到您的应用中,让用户可使用自己的 Twitter 帐号进行 Firebase 身份验证。

通过身份验证后,用户即可访问 Firebase 实时数据库和 Cloud Storage 中仅限用户访问的数据。

开始之前

  1. 将 Firebase 添加到您的 iOS 项目。在您的 Podfile 中添加以下 pod:
    pod 'Firebase/Auth'
    
  2. 在 Twitter 上将您的应用注册为开发者应用,并获取您的应用的 API 密钥API 密码
  3. 启用 Twitter 登录:
    1. Firebase 控制台中,打开 Authentication(身份验证)部分。
    2. 登录方法标签上,启用 Twitter 登录方法,然后指定从 Twitter 获取的 API 密钥API 密码
    3. 然后,请务必转到 Twitter 应用配置,在您的应用的设置页面上,将 Firebase OAuth 重定向 URI(例如 my-app-12345.firebaseapp.com/__/auth/handler)设置为回调网址

      在 Twitter 控制台中设置重定向 URI 时,请务必选择 Enable Callback Locking

      回调锁定默认处于停用状态,为了防止 Firebase 安全令牌被未经授权的第三方拦截,必须启用此功能。

进行 Firebase 身份验证

  1. 开发者文档中的说明操作,将 Twitter 登录机制集成到您的应用中。

    buttonWithLogInCompletionlogInWithCompletion 的回调方法中,获取登录会话的 Twitter 身份验证令牌和 Twitter 身份验证令牌密码。例如:

    Swift

    let logInButton = TWTRLogInButton(logInCompletion: { session, error in
      if (session != nil) {
        let authToken = session.authToken
        let authTokenSecret = session.authTokenSecret
        // ...
      } else {
          // ...
      }
    })
    

    Objective-C

     TWTRLogInButton *logInButton =
         [TWTRLogInButton buttonWithLogInCompletion:^(TWTRSession* session,
                                                      NSError* error) {
      if (session) {
        NSString *authToken = session.authToken;
        NSString *authTokenSecret = session.authTokenSecret;
        // ...
      } else {
        // ...
      }
    }];
    
  2. UIApplicationDelegate 中导入 Firebase 模块:

    Swift

    import Firebase
    

    Objective-C

    @import Firebase;
    
  3. 配置一个 FirebaseApp 共享实例(通常在应用的 application:didFinishLaunchingWithOptions: 方法中配置):

    Swift

    // Use Firebase library to configure APIs
    FirebaseApp.configure()
    

    Objective-C

    // Use Firebase library to configure APIs
    [FIRApp configure];
    
  4. 用户成功登录之后,在 didCompleteWithResult:error: 实现中使用 Twitter 身份验证令牌和 Twitter 身份验证令牌密码换取 Firebase 凭据:

    Swift

    let credential = TwitterAuthProvider.credential(withToken: session.authToken, secret: session.authTokenSecret)
    

    Objective-C

    FIRAuthCredential *credential =
        [FIRTwitterAuthProvider credentialWithToken:session.authToken
                                             secret:session.authTokenSecret];
    
  5. 最后,使用 Firebase 凭据进行 Firebase 身份验证:

    Swift

    Auth.auth().signInAndRetrieveData(with: credential) { (authResult, error) in
      if let error = error {
        // ...
        return
      }
      // User is signed in
      // ...
    }
    

    Objective-C

    [[FIRAuth auth] signInAndRetrieveDataWithCredential:credential
                                             completion:^(FIRAuthDataResult * _Nullable authResult,
                                                          NSError * _Nullable error) {
      if (error) {
        // ...
        return;
      }
      // User successfully signed in. Get user data from the FIRUser object
      if (authResult == nil) { return; }
      FIRUser *user = authResult.user;
      // ...
    }];
    
  6. 可选:向用户个人资料添加电子邮件地址。 当用户使用 Twitter 登录您的应用时,Firebase 无法获取他们的电子邮件地址。如果您希望向使用 Twitter 进行登录的用户的个人资料添加电子邮件地址,请提示用户输入电子邮件地址,然后调用 updateEmail,如以下示例所示:

    Swift

    Auth.auth().currentUser?.updateEmail(to: email) { (error) in
      // ...
    }
    

    Objective-C

    [[FIRAuth auth].currentUser updateEmail:userInput completion:^(NSError *_Nullable error) {
      // ...
    }];
    

后续步骤

在用户首次登录后,系统会创建一个新的用户帐号,并将其与该用户登录时使用的凭据(即用户名和密码、电话号码或者身份验证提供方信息)相关联。此新帐号存储在您的 Firebase 项目中,您项目中的每个应用都可以使用此帐号来识别用户,无论用户采用何种方式登录。

  • 在您的应用中,您可以从 FIRUser 对象获取用户的个人资料基本信息。请参阅管理用户

  • 在您的 Firebase 实时数据库和 Cloud Storage 安全规则中,您可以从 auth 变量获取已登录用户的唯一身份用户 ID,然后用此 ID 来控制用户可以访问哪些数据。

您可以允许用户通过多种身份验证提供方服务登录您的应用,只需将多个身份验证提供方凭据关联至现有用户帐号即可。

要让用户退出帐号,可调用 signOut:

Swift

    let firebaseAuth = Auth.auth()
do {
  try firebaseAuth.signOut()
} catch let signOutError as NSError {
  print ("Error signing out: %@", signOutError)
}
  

Objective-C

    NSError *signOutError;
BOOL status = [[FIRAuth auth] signOut:&signOutError];
if (!status) {
  NSLog(@"Error signing out: %@", signOutError);
  return;
}

您可能还需要添加适用于所有身份验证错误的错误处理代码。请参阅处理错误

发送以下问题的反馈:

此网页
需要帮助?请访问我们的支持页面