ios9:FBSDK currentAccessToken nil

时间:2016-08-28 06:58:35

标签: ios swift fbsdk

FBSDKAccessToken currentAccessToken nil after quitting app

我查看了许多相关的主题,我的案例中的解决方案仍然难以辨认。

这是我的AppDelegate.swift文件:

    func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {

   FBSDKApplicationDelegate.sharedInstance().application(application, didFinishLaunchingWithOptions: launchOptions)

  if let accessToken = FBSDKAccessToken.currentAccessToken(){
    print(accessToken)
  }else{
    print("Not logged In.")
  }

  return true
}

   func application(application: UIApplication,
               openURL url: NSURL, options: [String: AnyObject]) -> Bool {


return GIDSignIn.sharedInstance().handleURL(url,
                                            sourceApplication: options[UIApplicationOpenURLOptionsSourceApplicationKey] as? String,
                                            annotation: options[UIApplicationOpenURLOptionsAnnotationKey])


}


func application(application: UIApplication, openURL url:NSURL, sourceApplication: String?, annotation: AnyObject) -> Bool {
return FBSDKApplicationDelegate.sharedInstance().application(application, openURL: url,sourceApplication: sourceApplication, annotation: annotation)
 }

因此,在应用启动时,accessTokennil

当我尝试刷新访问令牌时,它不会这样做,因为你无法引用nil用户访问令牌。我想也许它会缓存一个过期的用户令牌。它仍然很奇怪,因为我正在调用FBSDK,它应返回当前用户令牌,即使它已过期。在我的情况下,它返回nil

以下是我尝试使用my currentAccessToken

的方式
func fetchFBInfoForLogin(){
let parameters = ["fields": "email, first_name, last_name"]

if (FBSDKAccessToken.currentAccessToken() != nil) {
  print("current access token is not nil")
  // User is logged in, do work such as go to next view controller.
  let graphRequest : FBSDKGraphRequest = FBSDKGraphRequest(graphPath:  "me", parameters: nil)
  graphRequest.startWithCompletionHandler({ (connection, result, error) -> Void in

    if ((error) != nil)
    {
      // Process error
      print("Error: \(error)")
    }
    else
    {
      print(result.valueForKey("id") as? String)
      print(result.valueForKey("name") as? String)
      print(result.valueForKey("email") as? String)

    }
  })

} else {

  //refresh

  FBSDKAccessToken.refreshCurrentAccessToken{ (connection, result, error) -> Void in
    if error != nil {
      print(error)
      return
    }
    print(FBSDKAccessToken.currentAccessToken())
    print("refresh doesn't work?")
    let parameters = ["fields": "email, first_name, last_name"]
    let graphRequest : FBSDKGraphRequest = FBSDKGraphRequest(graphPath:  "me", parameters: parameters)
    graphRequest.startWithCompletionHandler({ (connection, result, error) -> Void in

      if ((error) != nil)
      {
        // Process error
        print("Error: \(error)")
      }
      else
      {
        print(result.valueForKey("id") as? String)
        print(result.valueForKey("name") as? String)
        print(result.valueForKey("email") as? String)

      }
    })

  }   
}
}

供将来参考: 我没有在我的帖子Facebook SDK login never calls back my application on iOS 9

中使用正确的AppDelegate方法拨打我的FBSDK代表电话。

因此,为什么我必须手动关闭我的FB登录,这导致回调的结果为result.isCancelled,因此我没有得到任何用户令牌。

1 个答案:

答案 0 :(得分:1)

如果您希望来自login-和logout-events的通知实现FBSDKLoginButtonDelegate协议。

class FirstViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, FBSDKLoginButtonDelegate {

    func loginButton(loginButton: FBSDKLoginButton!, didCompleteWithResult result: FBSDKLoginManagerLoginResult!, error: NSError!) {
        if ((error) != nil) {
            // Process error
        } else if result.isCancelled {
            // Handle cancellations
        } else {
            let graphRequest : FBSDKGraphRequest = FBSDKGraphRequest(graphPath: "me", parameters: ["fields" : "id, email, name"])
            graphRequest.startWithCompletionHandler({ (connection, result, error) -> Void in
                if ((error) != nil) {
                    //print("Error: \(error)")
                } else {
                    if let user : NSString = result!.valueForKey("name") as? NSString {
                        print("user: \(user)")
                    }
                    if let id : NSString = result!.valueForKey("id") as? NSString {
                        print("id: \(id)")
                    }
                    if let email : NSString = result!.value(forKey: "email") as? NSString {
                        print("email: \(email)")
                    }
                }
            })
        }
    }
}

HTH。