gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 13:33:01 25 4
gpt4 key购买 nike

我正在尝试使用 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)

When I don't type anything and hit login it crashes with this error (i have measures to prevent the app from crashing because of this, possiably side affect of the bigger issue):

<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开始制作应用程序的尝试都让我感到困惑,因为这个,我看到了两个单独的应用程序,我在其中下载了结局项目,但我没有无法运行它,因为在 pod 目录中(Firebase 和 ios 9.2 制作时的所有位置,并且拥有 Firebase 的所有框架),它说“/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS9.0.sdk/System/Library/Frameworks/CFNetwork.framework”,我无法更改它,因为当我转到小目录更改按钮时,我必须进入 xcode 的包内容,但它不允许我这样做那个

The inline error when I am redirected

Second files inline error (same)

这是当应用程序崩溃时我收到错误消息的地方(2处)

import Foundation     import Firebaselet 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 UIKitimport Firebaseclass 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    }

最佳答案

userId id 很可能为 nil,一般来说,最好捕获它为 nil 的情况,如下所示

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,因为它从未经过身份验证,现在为零。不确定为什么按钮的 IBAction 被调用,但检查 IB 中的操作和导出。

此外,

var CURRENT_USER

有点可疑。

根据变量的名称,我希望它包含当前用户(可能是用户类?)。

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

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

CURRENT_USER.unauth() 

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

关于swift - Firebase swift ios登录系统错误断言失败/Exec_BAD_INSTRUNCTION(代码= EXC_i386_INVOP,子代码= 0x0),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36376068/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com