首页 文章

Firebase swift ios登录系统错误断言失败/ Exec_BAD_INSTRUNCTION(代码= EXC_i386_INVOP,子代码= 0x0)

提问于
浏览
0

我试图在firebase中使用内置的身份验证系统,并遵循此TuT这样做

Firebase Login Tutorial

我可以运行我的应用程序但是当我去登录并键入有效(或无效)登录电子邮件和密码时,它会在控制台中因此错误而崩溃:

Assertion failed: (request.URL), function -[FSRWebSocket initWithURLRequest:protocols:queue:andUserAgent:], file /Users/vikrum/dev/git/firebase-client-objc/Firebase/Firebase/Libraries/SocketRocket/FSRWebSocket.m, line 302.
(lldb)

当我没有输入任何内容并点击登录时,它会因此错误而崩溃(我有措施防止应用程序因此而崩溃,可能会对更大问题造成影响):

<pre>fatal error: unexpectedly found nil while unwrapping an Optional value</pre>

下面的内联错误与控制器错误相同

编辑:我注意到在框架中我的应用程序的pod目录中然后ios文件夹中的内容是(我的层次结构带有红色错误** LINKhttp://i.stack.imgur.com/IHCQw.png)以红色突出显示 . 4个框架的目录是iPhoneOS9.0.sdk由于某种原因我只有一个iPhoneOS.sdk和iPhoneOS9.2.sdk也是firebase,而它下面的另一个框架有奇怪的目录位置[(他们都去了这个位置* * LINKhttp://i.stack.imgur.com/Z6dX5.png)我不知道如何解决它的问题(我不完全确定这是导致我的应用程序在我尝试后崩溃的错误登录,但它是我见过的唯一错误,所以它必须是)

编辑2:我一直在环顾四周,每个最近的啧啧制作一个应用程序,至少ios 9一直困惑我因为这个,我已经看到2个单独的应用程序tuts我下载了压轴项目,我不能运行它,因为在pod目录(所有firebase和ios 9.2的制作地点和firebase的所有框架)它说“/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/ iPhoneOS9.0.sdk / System / Library / Frameworks / CFNetwork.framework“我不能改变它,因为当我去小dir更改按钮时,我必须进入xcode的包内容,它不会让我这样做

The inline error when I am redirected

Second files inline error (same)

这是应用程序崩溃时我被定向的地方,我得到了错误(2个地方)

import Foundation     
import Firebase

let BASE_URL = "https://baseball-pitcher-app.firebaseIO.comΩΩ"

let FIREBASE_REF = Firebase(url: BASE_URL)


var CURRENT_USER: Firebase
{
    ***let userID = NSUserDefaults.standardUserDefaults().valueForKey("uid") as! String*** ERROR IN THIS LINE

    let currentUser = Firebase(url: "\(FIREBASE_REF)").childByAppendingPath("users").childByAppendingPath(userID)

    return currentUser!
}

我发现奇怪的一件事是错误是在退出按钮,这是奇怪的,因为我从来没有按下它,因为错误发生 .

import UIKit
import Firebase

class LoginViewController: UIViewController, UITextFieldDelegate {

    @IBOutlet weak var userUsernameTextField: UITextField!
    @IBOutlet weak var userPasswordTextField: UITextField!
    @IBOutlet weak var logoutButton: UIButton!

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.

        self.userUsernameTextField.delegate = self;
        self.userPasswordTextField.delegate = self;
    }

    override func viewDidAppear(animated: Bool)
    {
        super.viewDidAppear(animated)

        if NSUserDefaults.standardUserDefaults().valueForKey("uid") != nil && CURRENT_USER.authData != nil
        {
            self.logoutButton.hidden = false
        }
    }


    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func textFieldShouldReturn(textField: UITextField) -> Bool {
        self.view.endEditing(true)
        return false
    }

    @IBAction func loginButtonTapped(sender: AnyObject) {

        let email = self.userUsernameTextField.text
        let password = self.userPasswordTextField.text

        if email != "" && password != ""
        {
            FIREBASE_REF.authUser(email, password: password, withCompletionBlock: { error, authData in

                if error == nil
                {
                    NSUserDefaults.standardUserDefaults().setValue(authData.uid, forKey: "uid")
                    print("Logged In :)")
                    self.logoutButton.hidden = false
                }
                else
                {
                    print(error)
                }
            })
        }
        else
        {
            let alert = UIAlertController(title: "Error", message: "Enter Email and Password.", preferredStyle: UIAlertControllerStyle.Alert)
            let action = UIAlertAction(title: "Ok", style: .Default, handler: nil)
            alert.addAction(action)
            self.presentViewController(alert, animated: true, completion: nil)
        }
    }

    @IBAction func logoutButtonTapped(sender: AnyObject) {
        CURRENT_USER.unauth()**** ERROR IN THIS LINE

        NSUserDefaults.standardUserDefaults().setValue(nil, forKey: "uid")
        self.logoutButton.hidden = true
    }

1 回答

  • 0

    userId id很可能是nil,一般来说最好 grab 没有的情况,比如这样

    if let userID = NSUserDefaults.standardUserDefaults().valueForKey("uid") as? String {
        print(userID) //do something with the user id here
    } else {
        print("The userID was nil.") //avoid the user id.
    }
    

    而第二个错误的原因是CURRENT_USER,因为它从未开始Auth'd现在为零 . 不知道为什么要调用按钮的IBAction,而是检查IB中的动作和出口 .

    而且,

    var CURRENT_USER

    有点怀疑 .

    基于var的名称,我希望它包含当前用户(可能是用户类?) .

    但是,在调用时,它会返回一个Firebase对象,该对象包含当前用户节点(/ appPath / users / users节点)的路径,而不包含其他用户数据 . 当用户进行身份验证时,它似乎不会填充 .

    不确定这是不是意图,或者是否在其他地方使用,但这样做

    CURRENT_USER.unauth()
    

    可能是一个问题,因为它不包含任何身份验证数据 .

相关问题