使用共享iOS密钥链启用跨应用程序Firebase身份验证

使用共享iOS密钥链启用跨应用程序Firebase身份验证,ios,swift,firebase,firebase-authentication,keychain,Ios,Swift,Firebase,Firebase Authentication,Keychain,我的问题听起来很简单:我有一个应用程序和一个共享扩展。我想做的是在共享扩展中检查是否有用户登录。为此我找到了这个 现在,如果用户登录,我将登录用户迁移到共享密钥链(在主应用程序中): 这并没有给我任何错误,所以我想它是有效的。但我目前面临两大问题: 1。主应用程序内部出现问题: 正如我所说,上面的代码运行良好,我还加载了一些数据,这些数据在用户第一次注册时运行良好。但是,如果我重新启动应用程序,用户不必再次登录,应该被引导到主视图,在主视图中我再次检索当前用户的数据。但这是失败的,因为curre

我的问题听起来很简单:我有一个应用程序和一个共享扩展。我想做的是在共享扩展中检查是否有用户登录。为此我找到了这个

现在,如果用户登录,我将登录用户迁移到共享密钥链(在主应用程序中):

这并没有给我任何错误,所以我想它是有效的。但我目前面临两大问题:

1。主应用程序内部出现问题:

正如我所说,上面的代码运行良好,我还加载了一些数据,这些数据在用户第一次注册时运行良好。但是,如果我重新启动应用程序,用户不必再次登录,应该被引导到主视图,在主视图中我再次检索当前用户的数据。但这是失败的,因为
currentUser
nil

static func getWishlists(completion: @escaping (_ success: Bool, _ dataArray: Any?, _ dropDownArray: Any?) -> Void) {
    
    let db = Firestore.firestore()
    let userID = Auth.auth().currentUser!.uid // <- throws error
    ...
但这是打印
而不是登录
,即使用户刚刚在主应用程序中登录


我不知道我到底做错了什么,在文档中找不到任何东西。也许这就是我为用户检索数据的方式。也许我也需要用那里的
accessGroup
调用一些东西,但我被卡住了。。。谢谢你的帮助

我不太确定您的问题,但您不是应该更改一组您自己的userAccessToken吗

do {
      try Auth.auth().useUserAccessGroup("XXXXXXXXXXXXX")
    } catch let error as NSError {
      print("Error changing user access group: %@", error)
    }
    
    if Auth.auth().currentUser != nil {
      // User is signed in.
      print("signed in")
    } else {
      // No user is signed in.
      print("not signed in")
    }

将您的apps userAccessGroup替换到我放置xxxxxxxxxxxx占位符的位置。

刚刚确认,您具有钥匙链共享功能,对吗?@Pastre是,在具有相同标识的应用程序和扩展上,字典的
NSError.userInfo
NSLocalizedFailureReasonErrorKeysay?taruntygi我不知道如何读取该错误…抱歉,它在错误日志中可见-这部分
NSLocalizedFailureReason=SecItemCopyMatching(0)
。这似乎是一个环境/配置问题。查看此线程-完全相同的错误。
    do {
      try Auth.auth().useUserAccessGroup("teamID.com.example-app.group")
    } catch let error as NSError {
      print("Error changing user access group: %@", error)
    }
    
    if Auth.auth().currentUser != nil {
      // User is signed in.
      print("signed in")
    } else {
      // No user is signed in.
      print("not signed in")
    }
do {
      try Auth.auth().useUserAccessGroup("XXXXXXXXXXXXX")
    } catch let error as NSError {
      print("Error changing user access group: %@", error)
    }
    
    if Auth.auth().currentUser != nil {
      // User is signed in.
      print("signed in")
    } else {
      // No user is signed in.
      print("not signed in")
    }