выдает эту ошибку: значение типа «StorageMetadata» не имеет члена «downloadURL» - PullRequest
0 голосов
/ 30 ноября 2018

Мне нужна помощь с этим кодированием, я не уверен, что произошло. Пожалуйста, не дублируйте этот вопрос или подобное, так как я уже пробовал любое решение в Интернете, и ничего не помогло.Я пытаюсь получить «доступ к URL-адресу для загрузки после загрузки».

Я попытался: я использую автозаполнение метаданных, для которых не отображается опция URL-адреса, ближе всего я получил metadata.path или metadata.storageReference.

2-я попытка: я знаю, что API был изменен в версии 5.0.0, поэтому я использую метод downloadURL StorageReference.это также дает мне ошибку, может быть, я помещаю ее в неправильную строку кода или еще.

вот класс: -

import UIKit
import Firebase
import FirebaseDatabase
import FirebaseStorage
import SwiftKeychainWrapper

class SignUpVC: UIViewController, UIImagePickerControllerDelegate,UINavigationControllerDelegate{

@IBOutlet weak var userImagePicker: UIImageView!
@IBOutlet weak var userNameField: UITextField!
@IBOutlet weak var SignUpBtn: UIButton!

var userId: String!
var emailField: String!
var passwordField: String!
var imagePicker: UIImagePickerController!
var imageselected = false
var userName: String!

//Do any Additional SetUp after  loading the view
override func viewDidLoad() {
    super .viewDidLoad()

    imagePicker = UIImagePickerController()
    imagePicker.delegate = self
    imagePicker.allowsEditing = true
}
override func viewDidAppear(_ animated: Bool) {

    if let _ = KeychainWrapper.standard.string(forKey: "uid") {
        performSegue(withIdentifier: "ToMessges", sender: nil)
        }
    }
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
    if let image = info[UIImagePickerController.InfoKey.editedImage] as? UIImage{
        userImagePicker.image = image
        imageselected = true
    }else{
        print("Image wasent selected!")
        imagePicker.dismiss(animated: true, completion: nil)
    }
}
func setuser(img: String){
    let userData = [
        "username": userName!,"userimage": img]
    KeychainWrapper.standard.set(userId, forKey: "uid")
    let location = Database.database().reference().child("users").child(userId)
    location.setValue(userData)
    dismiss(animated: true, completion: nil)
}

func uploadImg (){
        if userNameField.text == nil {
            SignUpBtn.isEnabled = false

        }else {
            userName = userNameField.text
            SignUpBtn.isEnabled = true
        }

        guard let img = userImagePicker.image, imageselected == true else {
            print("Image needs to be selected")

            return
        }

        if let imgData = img.jpegData(compressionQuality: 0.2) {

            let imgUid = NSUUID().uuidString
            let metadata = StorageMetadata()
            metadata.contentType = "image/Jpeg"
            Storage.storage().reference().child(imgUid).putData(imgData, metadata:metadata){(metaData,error
                ) in

                if error != nil {
                print("Did not upload Image!")

            }else {
                   print("Uploaded")

                    let downloadURL = metadata.downloadURL()?.absoulteString      //error here 

                    if let url = downloadURL {
                        self.setUser(img:url)
                    }
                }
            }
        }
    }

1 Ответ

0 голосов
/ 30 ноября 2018

Согласно Firebase doc , у вас может не быть прямого свойства downloadURL в StorageMetadata классе.Поэтому вам, возможно, придется использовать dictionaryRepresentation и получить доступ к ссылке для скачивания, используя mediaLink key.

Пример:

if let downloadURL = metadata.dictionaryRepresentation()["mediaLink"] as? String{

     self.setUser(img:downloadURL)
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...