В принципе, у меня есть один класс под названием facebookLogin.swift, страница входа и ViewController.Swift на главной странице. Я правильно закодировал все материалы для входа в Facebook, и все это работает, я могу войти в систему и выйти из нее с помощью кнопки, которую предоставляет FBSDK, а также настраиваемой кнопки, которую я определил. Тем не менее, я не могу понять, как перейти на страницу ViewController.swift, если пользователь вошел в системуКак программно запустить в другой viewController, если ваш пользователь зарегистрировался через Facebook
Вот код facebookLogin.swift:.
import UIKit
import FBSDKCoreKit
import FBSDKLoginKit
class facebookLogin: UIViewController, FBSDKLoginButtonDelegate {
var loginStatus = false;
@IBOutlet weak var facebookOutlet: UIButton!
override func viewDidLoad() {
super.viewDidLoad()
super.viewDidLoad()
let loginButton = FBSDKLoginButton()
view.addSubview(loginButton)
loginButton.center = view.center
loginButton.delegate = self;
loginButton.readPermissions = ["email","public_profile"]
}
@IBAction func facebookAction(_ sender: Any) {
customFBLogin()
if (FBSDKAccessToken.current() != nil) {
NSLog("it works")
}
}
func customFBLogin() {
FBSDKLoginManager().logIn(withReadPermissions: ["email","public_profile"], from: self) { (result, err) in
if err != nil {
print("Facebook Login Error Failed \(err)")
return;
}
self.showEmailAddress();
self.loginStatus = true;
}
}
func loginButtonDidLogOut(_ loginButton: FBSDKLoginButton!) {
print("Did log out of Facebook")
}
func loginButton(_ loginButton: FBSDKLoginButton!, didCompleteWith result: FBSDKLoginManagerLoginResult!, error: Error!) {
if error != nil {
print(error)
return;
} else {
print("Successfuly logged into Facebook");
showEmailAddress()
}
}
func showEmailAddress() {
FBSDKGraphRequest(graphPath: "/me", parameters: ["fields": "id, name, email"]).start(completionHandler: { (connection, result, err) in
if err != nil {
print("Failed to start graph request \(err)")
return;
}
print(result)
})
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
/*
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
}
*/
}
Вот соответствующий код из AppDelegate .swift файл:
import UIKit
import CoreData
import Firebase
import FBSDKCoreKit
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
FIRApp.configure()
FBSDKApplicationDelegate.sharedInstance().application(application, didFinishLaunchingWithOptions: launchOptions)
let mainStoryBoard = UIStoryboard.init(name: "Main", bundle: nil)
self.window = UIWindow(frame: UIScreen.main.bounds)
var initialViewController: UIViewController
if(FBSDKAccessToken.current() != nil) {
let vc = mainStoryBoard.instantiateViewController(withIdentifier: "ViewController") as! ViewController
initialViewController = vc
} else{
initialViewController = mainStoryBoard.instantiateViewController(withIdentifier: "facebookLogin")
}
self.window?.rootViewController = initialViewController
self.window?.makeKeyAndVisible()
return true
}
func application(_ app: UIApplication, open url: URL, options: [UIApplicationOpenURLOptionsKey : Any] = [:]) -> Bool {
let handled = FBSDKApplicationDelegate.sharedInstance().application(app, open: url, sourceApplication: options[UIApplicationOpenURLOptionsKey.sourceApplication] as! String!, annotation: options[UIApplicationOpenURLOptionsKey.annotation])
return handled;
}
в первой функции приложения в классе AppDelegate.swift, я нашел еще один учебник по StackOverflow, который предложил использовать этот код. Я ввел код и преобразовал синтаксис в swift3, но приложение ломается, когда я его запускаю. Это означает, что он знает, что я вошел в систему, но по какой-то причине segue не загружается, и это ломает приложение. Ошибка, которую я получаю, это Thread 1: sigabrt.
Вот как соответствующие пункты в истории правления выглядят, на первый начальный вид контроллера находится на левой стороне, и если пользователь вошел в систему, я хочу, чтобы приложение, чтобы начать с ViewController на правой 1
есть вы определили раскадровка идентификаторы? –
Вы используете реальное устройство? –