我正在使用Facebook SDK开发一个ios应用程序来登录。
我在故事板中设置了LogInViewController
作为初始视图控制器,用户使用FB帐户登录。
我有另一个ViewController,一旦用户登录就会正确加载。
在AppDelegate文件中,我正在检查currentAccessToken
,如果它不是nil,我将直接加载第二个ViewController,因为用户已经登录。
但是,如果我退出应用并重新启动它,currentAccessToken
总是为零。它只有在我按下主页按钮并在后台仍然在后台运行时重新打开应用程序时才有效。
以下是代码中的详细信息:
AppDelegate.swift
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
self.customNavigationBar()
if (!isIcloudAvailable()) {
self.displayAlertWithTitle("iCloud", message: "iCloud is not available." +
" Please sign into your iCloud account and restart this app")
return true
}
if (FBSDKAccessToken.currentAccessToken() != nil) {
self.instantiateViewController("MapViewController", storyboardIdentifier: "Main")
}
return FBSDKApplicationDelegate.sharedInstance().application(application, didFinishLaunchingWithOptions: launchOptions)
}
func application(application: UIApplication, openURL url: NSURL, sourceApplication: String?, annotation: AnyObject) -> Bool {
return FBSDKApplicationDelegate.sharedInstance().application(
application,
openURL: url,
sourceApplication: sourceApplication,
annotation: annotation)
}
func applicationWillResignActive(application: UIApplication) {
FBSDKAppEvents.activateApp()
}
func applicationDidBecomeActive(application: UIApplication) {
FBSDKAppEvents.activateApp()
}
LogInViewController.swift
override func viewDidLoad() {
super.viewDidLoad()
// Listen to the Facebook notification and when received, execute func handleFBSessionStateChangeWithNotification
NSNotificationCenter.defaultCenter().addObserver(self, selector:"handleFBSessionStateChangeWithNotification:", name: "SessionStateChangeNotification", object: nil)
}
func handleFBSessionStateChangeWithNotification(notification: NSNotification) {
// Switch to MapViewController when logged in
if ((FBSDKAccessToken.currentAccessToken()) != nil) {
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let mapViewController = storyboard.instantiateViewControllerWithIdentifier("MapViewController") as! MapViewController
self.presentViewController(mapViewController, animated: false, completion: nil)
}
}
我不知道它是否相关,但我也收到MapViewController
的警告,因为故事板中没有提出任何偏见:
警告:尝试显示视图不在的MapViewController 窗口层次结构!
答案 0 :(得分:57)
问题是因为你在调用
之前要求FBSDKAccessToken.currentAccessToken()
FBSDKApplicationDelegate.sharedInstance().application(application, didFinishLaunchingWithOptions: launchOptions)
您可以在调用上述行后随时检查访问令牌。
编辑:说明
上述行允许Facebook SDK处理launchOptions并提取必要的信息,以便识别并保留用户的应用程序。
如果用户已经登录,则只需初始化Facebook SDK,然后根据持久数据登录用户。
答案 1 :(得分:15)
我花了半天的时间来讨论这个问题。尽管确保所有委托方法都存在,FBSDKAccessToken.current()
总是返回nil。
事实证明,这是因为未启用Keychain Sharing(Xcode 8,iOS 10)。要修复,请转到应用 - >能力 - >钥匙串分享并开启。
完成此操作后,您仍必须完成授权过程并返回应用程序。以后一切都应该没问题。
答案 2 :(得分:0)
对于那些在appdelegate上设置FBSDKApplicationDelegate.sharedInstance()
后仍然遇到问题的人,如果你的Xcode控制台上出现错误就会出现这样的错误
Falling back to storing access token in NSUserDefaults because of simulator bug
这是模拟器错误,我尝试使用真实设备,它工作,访问令牌不再为零.. 所以也许在@Kal答案上回答@victor关于这个的评论..
答案 3 :(得分:-1)
如果您已经尝试过解决方案,但仍然遇到问题,请尝试此操作。
我的合作程序员和我正在使用Facebook Swift SDK中提供的LoginManager().login
方法。 (Xcode8,Swift 3,iOS 10)
导致该问题的一个可能操作是,当您成功登录并立即终止应用程序,然后再次打开您的应用程序并AccessToken.current
返回nil
。登录后,如果你等待20秒或更长时间(我们不确定确切的等待时间,我们等待7-20秒)并杀死应用程序,问题似乎就解决了。
我们不确定为什么会这样,但这解决了我们的问题,我们的猜测是可能存在网络延迟或错误。