Я загружаю изображение в хранилище Firebase и загружаю URL, чтобы получить изображение позже. Я добавил скриншот и больше кода. При печати (url) работает нормально, а при передаче URL-адреса значения в функцию storenewuser сохраняет ноль
This is the upload function:
Future uploadPic() async{
String filename = phoneNumber;
StorageReference ref = FirebaseStorage.instance.ref().child("User Profile Image").child(filename);
StorageUploadTask uploadTask = ref.putFile(_Image);
var downUrl = await (await uploadTask.onComplete).ref.getDownloadURL();
var url = downUrl.toString();
print(url);
if (!mounted) return;
setState(() {
ImageUrl=url;
});
}
SignUp and storing usersdata:
void Signup() async{
if(_key.currentState.validate()){
FirebaseAuth.instance.createUserWithEmailAndPassword(email: Email, password: Password).then((signedInUser){
uploadPic();
UserManagement().storeNewUser(Name,Email,phoneNumber,ImageUrl,RollNumber,Course,Semester,signedInUser.user, context);
}).catchError((e){
final snackBar = SnackBar(
content: Text(e.message),
);
Scaffold.of(context).showSnackBar(snackBar);
print(e);
});
}
else{
print("NULL");
}
}
storeNewUser(Name,Email/*,password*/,phonenumber,ImageUrl,rollnumber,course,sem,user,context){
Firestore.instance.collection('/users').document(user.uid).setData({
'Name' : Name,
'Email' : Email,
'Image Url' : ImageUrl,
'Phone Number' : phonenumber,
'Roll Number' : rollnumber,
'College' : 'Siliguri Institute of Technology',
'Course' : course,
'Semester' : sem
}).then((value){
Navigator.of(context).pop();
Navigator.pushReplacement(context, MaterialPageRoute(builder: (context) => SignUpCompletePage()));
}).catchError((e){
final snackBar = SnackBar(
content: Text(e.message),
);
Scaffold.of(context).showSnackBar(snackBar);
});
}
База данных:
Хранение: