- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为了在Cloud Firestore中创建配置文件信息,我尝试使用 NonExistingProfileForm 。
照片是从画廊中选择的,并上传到了Firebase存储中,但我似乎无法获取它的URL。
我无法将URL分配给 _imageUrl ,并且文档中有一个空值。
here's the image of firestore document with 'profilePic' key with empty value.
这是代码。
import 'package:comcrop/shared/shared.dart';
import 'package:comcrop/models/users.dart';
import 'package:comcrop/services/database.dart';
import 'package:firebase_storage/firebase_storage.dart';
import 'package:flutter/material.dart';
import 'package:image_picker/image_picker.dart';
import 'package:provider/provider.dart';
import 'dart:io';
class NonExistingProfileForm extends StatefulWidget {
@override
_NonExistingProfileFormState createState() => _NonExistingProfileFormState();
}
class _NonExistingProfileFormState extends State<NonExistingProfileForm> {
final _formKey = GlobalKey<FormState>();
// form values
String netimg =
'https://www.psychowave.org/wp-content/uploads/2015/06/cd1-960x960.jpg';
String _firstName;
String _lastName;
String _phoneNumber;
String _address;
String _imageUrl;
File _image;
@override
Widget build(BuildContext context) {
final user = Provider.of<User>(context);
Future getImage() async {
var image = await ImagePicker.pickImage(source: ImageSource.gallery);
setState(() {
_image = image;
});
}
Future uploadPic(BuildContext context) async {
StorageReference ref =
FirebaseStorage.instance.ref().child(user.uid);
StorageUploadTask task = ref.putFile(_image);
if (task.isComplete) {
setState(() {
_imageUrl = ref.getDownloadURL() as String;
print(_imageUrl);
});
}
}
return Form(
key: _formKey,
child: SingleChildScrollView(
child: Column(
children: <Widget>[
Text('add profile',
style: Theme.of(context).appBarTheme.textTheme.headline6),
SizedBox(height: 20.0),
Row(
children: [
CircleAvatar(
radius: 50,
backgroundImage: (_image != null)
? FileImage(
_image,
)
: NetworkImage(netimg),
),
SizedBox(width: 50),
FlatButton.icon(
onPressed: () => getImage(),
icon: Icon(
Icons.camera,
color: Colors.white,
),
label: Text('image',
style: Theme.of(context).textTheme.bodyText2),
),
],
),
SizedBox(height: 50),
TextFormField(
style: Theme.of(context).textTheme.bodyText2,
initialValue: '',
decoration: textInputDecoration.copyWith(labelText: 'first name'),
validator: (val) =>
val.isEmpty ? 'Please enter first name' : null,
onChanged: (val) => setState(() => _firstName = val),
),
SizedBox(height: 20.0),
TextFormField(
style: Theme.of(context).textTheme.bodyText2,
initialValue: '',
decoration: textInputDecoration.copyWith(labelText: 'last name'),
validator: (val) => val.isEmpty ? 'Please enter last name' : null,
onChanged: (val) => setState(() => _lastName = val),
),
SizedBox(height: 20.0),
TextFormField(
style: Theme.of(context).textTheme.bodyText2,
initialValue: '',
decoration:
textInputDecoration.copyWith(labelText: 'phone number'),
validator: (val) =>
val.length != 10 ? 'Please enter phone number' : null,
onChanged: (val) => setState(() => _phoneNumber = val),
),
SizedBox(height: 30.0),
TextFormField(
maxLines: 4,
style: Theme.of(context).textTheme.bodyText2,
initialValue: '',
decoration:
textInputDecoration.copyWith(labelText: 'genaral address'),
validator: (val) =>
val.isEmpty ? 'Please enter genaral address' : null,
onChanged: (val) => setState(() => _address = val),
),
SizedBox(height: 20.0),
SizedBox(
height: MediaQuery.of(context).viewInsets.bottom,
),
RaisedButton(
child:
Text('update', style: Theme.of(context).textTheme.button),
onPressed: () async {
uploadPic(context);
if (_formKey.currentState.validate()) {
await DatabaseService(uid: user.uid).updateUserData(
_firstName,
_lastName,
int.parse(_phoneNumber),
_address,
_imageUrl,
);
Navigator.pop(context);
}
}),
],
),
),
);
}
}
最佳答案
尝试等待:
await uploadPic(context);
await (await task.onComplete).ref.getDownloadURL()
关于flutter - 无法从Firebase存储中的上传图像获取.getDownloadURL(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62384198/
Uri downloaduri=taskSnapshot.getDownloadUrl();//here i cant use getdownloadurl() function
我想知道是否 getDownloadUrl在 Firebase 存储/谷歌云存储(一种获取存储上文件的公共(public) URL 的方法)上是一项付费操作。即使在通读之后 the documenta
为了在Cloud Firestore中创建配置文件信息,我尝试使用 NonExistingProfileForm 。 照片是从画廊中选择的,并上传到了Firebase存储中,但我似乎无法获取它的URL
我有一个函数,首先将图像保存到 Firebase,然后返回下载网址。现在我可以取回url(请参阅return url),但我不知道如何为整个函数返回它,因为它是嵌套,并且由于此函数异步运行,如果在 g
我尝试将图像上传到 Firebase 存储,然后从存储中获取下载网址,以便将其保存到我的数据库中。 注释掉的行有效,所以我知道它是“getDownloadURL”函数或我的存储引用中的问题。我有一个类
我正在将 pdf 上传到 Firebase Storage,并希望获取其下载网址。我正在使用以下代码: @Override protected void onActivityResult(int re
这个问题已经有答案了: How to get URL from Firebase Storage getDownloadURL (14 个回答) 已关闭 4 年前。 我正在尝试遵循有关“如何制作 Wh
通话时 task.getResult().getDownloadUrl().toString(); 我在 getDownloadUrl() 上遇到错误,不知道为什么?显示红线并且无法解析符号 if (
private void uploadImageToFirebaseStorage() { StorageReference profileImageRef = Firebas
这个问题在这里已经有了答案: How to return DataSnapshot value as a result of a method? (6 个答案) 关闭 4 年前。 此方法应该返回 d
到目前为止,从 Firebase 中的存储文件中获取 url 的方法,我曾经这样做过taskSnapshot.getDownloadUrl,但现在已弃用,我应该使用哪种方法? 最佳答案 正如 Doug
private void uploadImageToFirebaseStorage() { StorageReference profileImageRef = Firebas
要将图像上传到Firebase Storage,我将addOnSuccessListener附加到StorageReference的实例上。在覆盖 onSuccess 方法时,我在 taskSnaps
我正在尝试使用新的@angular/fire 5.1.0使用 AngularFireStorage 查看上传到 firebase 的图像。我曾经能够在 angularfire2 中使用 task.do
你能帮我解决这个错误吗? getDownloadUrl();说无法解析 getDownloadUrl() 的符号变量。我知道 getDownloadUrl(); 已被弃用,我尝试阅读更新后的文档,但我
private void storeFirestore(@NonNull Task task, String user_name) { Uri download_uri; if(tas
我在将图片上传到 Firebase 时遇到问题。 当我上传图像时,我得到一个 taskSnapshot.getDownloadUrl() token ,当我查看 firebase 存储时,有一个不同的
根据我读过的文档 ref.getDownloadURL(); 应该返回一个我可以在 img src 中使用的链接。 这是我的代码:这就是我启动 firebase 的方式: this.storage =
let storage = firebase.storage(); let storageRef = storage.ref("EnglishVideos/" + movieTitle + "/" +
真的需要帮助,这是我的 Firebase 存储安全规则 service firebase.storage { match /b/shoppinglist-XXXX.appspot.com/o {
我是一名优秀的程序员,十分优秀!