我正在尝试在IOS(Swift)上使用Firebase将用户选择的图像文件上传到firebase存储。 我已经对用户进行了身份验证,因此这不是问题所在。 下面你可以看到我正在尝试使用的视图控制器,但是当它尝试上传图像时,我收到一条错误消息说:
对象images / vesVLmkqS2cCLQTJOjv9CFe8mh22 / 0524729A-855E-4E63-8C11-50F4C4B1A905不存在。
(你可以在代码中看到这条路径的中间部分是用户uid,所以我肯定有一个经过身份验证的用户)
我试图在测试像myimage.png之类的值之前简化这条路径,但没有帮助,我得到了同样的错误。
我已经尽力了,请帮助我,因为我在firebase文档中找不到任何相关内容。
以下代码会在视图加载时自动打开图像选择器。如果用户选择图像,我们将其设置为图像视图。当用户单击上载按钮时,控制器会尝试将文件上载到firebase存储。
import UIKit
import Firebase
class ShareViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate {
@IBOutlet weak var imageView: UIImageView!
let imagePicker = UIImagePickerController()
override func viewDidLoad() {
super.viewDidLoad()
imagePicker.delegate = self
imagePicker.allowsEditing = false
imagePicker.sourceType = .photoLibrary
present(imagePicker, animated: true, completion: nil)
}
@IBAction func onPictureTapped(_ sender: Any) {
present(imagePicker, animated: true, completion: nil)
}
@IBAction func onUploadClicked(_ sender: Any) {
if let pickedImage = imageView.image, let imageData = UIImagePNGRepresentation(pickedImage) {
let storageRef = Storage().reference()
let imageRef = storageRef.child("images/\(Auth.auth().currentUser!.uid)/\(NSUUID().uuidString)")
imageRef.putData(imageData, metadata: nil) { (metadata, error) in
if error != nil {
NSLog(error!.localizedDescription)
}
self.navigationController?.popToRootViewController(animated: true)
}
}
}
internal func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
if let pickedImage = info[UIImagePickerControllerOriginalImage] as? UIImage {
imageView.contentMode = .scaleAspectFit
imageView.image = pickedImage
}
self.dismiss(animated: true, completion: nil)
}
}
答案 0 :(得分:3)
好的,我发现了问题:
// Instead of this:
Storage().reference()
// You need to use this
Storage.storage().reference()
这是荒谬的,没有关于此的警告,也不会崩溃的应用程序。非常讨厌,我花了至少5个小时才找到