Проблема входа в Facebook в Swift и iOS9

Я пытался создать приложение клона Tinder. Прямо сейчас я должен войти в свою учетную запись Facebook, захватить мой профиль и показать мою отображаемую картинку.

Я импортировал последнюю версию FBSDK, правильно подтвердил свой plist ( скриншот Plist) и использовал функцию graphRequest, чтобы получить изображение моего профиля, но я продолжаю получать следующую ошибку.

-canOpenURL: сбой для URL: "fbauth2:/" - ошибка: "(ноль)"

Я очистил свою сборку, перезапустил симулятор, перезапустил мою машину и полностью закомментировал мой код разбора.

Я раскомментировал весь мой код синтаксического анализа (который я развернул через Heroku), чтобы не упростить код.

Я гуглил проблему и искал переполнение стека и github в течение более 2 недель, и до сих пор не нашел решения.

Я читал комментарии о том, как эта проблема представляет собой красную сельдь из-за интеграции SDK Facebook с iOS 9.

Я хочу знать, что я делаю неправильно. Я новичок в кодировании и мне нужна помощь. Все, чего я хочу достичь сейчас, - это войти в свою учетную запись Facebook (что я могу сделать), авторизовать мое приложение (что я тоже могу сделать) и увидеть фотографию моего профиля в UiImageView (что я НЕ МОГУ сделать). Таким образом, я могу продолжать строить приложение вместе с моим курсом.

    /**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/

//current project 02-04-16

import UIKit
import Parse
import Bolts
import FBSDKCoreKit
import FBSDKLoginKit
import ParseFacebookUtilsV4


// If you want to use any of the UI components, uncomment this line
// import ParseUI

// deleted parseFacebookUtils and added ParseFacebookUtilsV4 so that PFFacebookUtils.intializeFacebookWithLaunchOptions would work. Replace parseFacebookUtils if needed to go back to old code (19-04-16).

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?

    //--------------------------------------
    // MARK: - UIApplicationDelegate
    //--------------------------------------



    func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
        // Enable storing and querying data from Local Datastore.
        // Remove this line if you don't want to use Local Datastore features or want to use cachePolicy.

//        Parse.enableLocalDatastore()
//        
//        let parseConfiguration = ParseClientConfiguration(block: { (ParseMutableClientConfiguration) -> Void in
//            
//            ParseMutableClientConfiguration.applicationId = "tinder9121hughglass1234"
//            ParseMutableClientConfiguration.clientKey = "sam123456hibabina"
//            ParseMutableClientConfiguration.server = "https://tinder-sam2.herokuapp.com//parse"


            PFFacebookUtils.initializeFacebookWithApplicationLaunchOptions(launchOptions)



//            Uncomment these lines if you want to enable Parse 
//            PFUser.enableAutomaticUser()
//            
//
//            PFUser.logOut()

//            let defaultACL = PFACL();


            //this is the current project 23-03-16


//            PFUser.enableAutomaticUser()
//            Parse.setApplicationId("tinder9121hughglass1234", clientKey: "sam123456hibabina")



            //this code has been // temporarily 05-04-16 ***

//            
//            let fbLoginManager : FBSDKLoginManager = FBSDKLoginManager()
//            fbLoginManager.logInWithReadPermissions(["public_profile"], handler: { (result, error) in
//            
//                
//            })
//            
//            PFUser.enableAutomaticUser()
//            
//            

//        })

//          edited again here!
//        let PFObject = PFUser.currentUser()
//
//        PFUser.enableAutomaticUser()
//
//        let acl = PFACL()
//        acl.publicReadAccess = true
//        acl.publicWriteAccess = true
//        PFObject?.ACL = acl

//        let defaultACL = PFACL();

        // If you would like all objects to be private by default, remove this line.
//        defaultACL.publicReadAccess = true

//        PFACL.setDefaultACL(defaultACL, withAccessForCurrentUser: true)

        if application.applicationState != UIApplicationState.Background {
            // Track an app open here if we launch with a push, unless
            // "content_available" was used to trigger a background push (introduced in iOS 7).
            // In that case, we skip tracking here to avoid double counting the app-open.

            let preBackgroundPush = !application.respondsToSelector("backgroundRefreshStatus")
            let oldPushHandlerOnly = !self.respondsToSelector("application:didReceiveRemoteNotification:fetchCompletionHandler:")
            var noPushPayload = false;
            if let options = launchOptions {
                noPushPayload = options[UIApplicationLaunchOptionsRemoteNotificationKey] != nil;
            }
            if (preBackgroundPush || oldPushHandlerOnly || noPushPayload) {
                PFAnalytics.trackAppOpenedWithLaunchOptions(launchOptions)
            }
        }

        //
        //  Swift 1.2
        //
        //        if application.respondsToSelector("registerUserNotificationSettings:") {
        //            let userNotificationTypes = UIUserNotificationType.Alert | UIUserNotificationType.Badge | UIUserNotificationType.Sound
        //            let settings = UIUserNotificationSettings(forTypes: userNotificationTypes, categories: nil)
        //            application.registerUserNotificationSettings(settings)
        //            application.registerForRemoteNotifications()
        //        } else {
        //            let types = UIRemoteNotificationType.Badge | UIRemoteNotificationType.Alert | UIRemoteNotificationType.Sound
        //            application.registerForRemoteNotificationTypes(types)
        //        }

        //
        //  Swift 2.0
        //
        //        if #available(iOS 8.0, *) {
        //            let types: UIUserNotificationType = [.Alert, .Badge, .Sound]
        //            let settings = UIUserNotificationSettings(forTypes: types, categories: nil)
        //            application.registerUserNotificationSettings(settings)
        //            application.registerForRemoteNotifications()
        //        } else {
        //            let types: UIRemoteNotificationType = [.Alert, .Badge, .Sound]
        //            application.registerForRemoteNotificationTypes(types)
        //        }

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

    }

    //--------------------------------------
    // MARK: Push Notifications
    //--------------------------------------

    func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {
        let installation = PFInstallation.currentInstallation()
        installation.setDeviceTokenFromData(deviceToken)
        installation.saveInBackground()

        PFPush.subscribeToChannelInBackground("") { (succeeded: Bool, error: NSError?) in
            if succeeded {
                print("ParseStarterProject successfully subscribed to push notifications on the broadcast channel.\n");
            } else {
                print("ParseStarterProject failed to subscribe to push notifications on the broadcast channel with error = %@.\n", error)
            }
        }
    }

    func application(application: UIApplication, didFailToRegisterForRemoteNotificationsWithError error: NSError) {
        if error.code == 3010 {
            print("Push notifications are not supported in the iOS Simulator.\n")
        } else {
            print("application:didFailToRegisterForRemoteNotificationsWithError: %@\n", error)
        }
    }

    func application(application: UIApplication, didReceiveRemoteNotification userInfo: [NSObject : AnyObject]) {
        PFPush.handlePush(userInfo)
        if application.applicationState == UIApplicationState.Inactive {
            PFAnalytics.trackAppOpenedWithRemoteNotificationPayload(userInfo)
        }
    }
    ///////////////////////////////////////////////////////////
    // Uncomment this method if you want to use Push Notifications with Background App Refresh
    ///////////////////////////////////////////////////////////
    // func application(application: UIApplication, didReceiveRemoteNotification userInfo: [NSObject : AnyObject], fetchCompletionHandler completionHandler: (UIBackgroundFetchResult) -> Void) {
    //     if application.applicationState == UIApplicationState.Inactive {
    //         PFAnalytics.trackAppOpenedWithRemoteNotificationPayload(userInfo)
    //     }
    // }

    //--------------------------------------
    // MARK: Facebook SDK Integration
    //--------------------------------------

    ///////////////////////////////////////////////////////////
    // Uncomment this method if you are using Facebook
    ///////////////////////////////////////////////////////////
    // func application(application: UIApplication, openURL url: NSURL, sourceApplication: String?, annotation: AnyObject?) -> Bool {
    //     return FBAppCall.handleOpenURL(url, sourceApplication:sourceApplication, session:PFFacebookUtils.session())
    // }

    func applicationDidBecomeActive(application: UIApplication) {

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

        return FBSDKApplicationDelegate.sharedInstance().application(application, openURL: url, sourceApplication: sourceApplication, annotation: annotation)

    }
}

1 ответ

Решение

Попробуйте добавить эту строку в свой Info.plist: <string>fbauth2</string>

Info.plist

Другие вопросы по тегам