必须提供电子邮件地址/电子邮件地址格式错误



我得到了"flutter: [firebase_auth/missing-email]必须提供电子邮件地址。"当我注册的时候。使用dummy@gmail.com

和"flutter: [firebase_auth/invalid-email]电子邮件地址格式错误。"当我用注册账户登录时。(以前有过一个有效的电子邮件,并通过firebase网站创建了一个帐户,也获得了相同的MSG)

我看到trim()作为一个可能的解决方案,但不知道如何实现它。我确保没有空位了……你能告诉我我的代码有什么错误或缺失吗?

这里是一些代码从我的注册页面(看起来几乎相同在我的登录页面),让我知道如果你需要看到更多

String email = '';
String password = '';
String error = '';
TextFormField(
textInputAction: TextInputAction.next,
style: TextStyle(color: Colors.white),
decoration: textInputDecoration.copyWith(
hintText: ('Enter Email'),
hintStyle: TextStyle(color: Colors.white),
enabledBorder: UnderlineInputBorder(
borderSide: BorderSide(color: Colors.white),
),
),
keyboardType: TextInputType.emailAddress,
validator: (value) {
if (value!.isEmpty) {
return 'Email is required';
}
if (value.isNotEmpty) {
final RegExp regex = RegExp(
r'^(([^<>()[]\.,;:s@"]+(.[^<>()[]\.,;:s@"]+)*)|(".+"))@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}])|(([a-zA-Z-0-9]+.)+[a-zA-Z]{2,}))$');
if (!regex.hasMatch(value))
return 'Enter a valid email';
else
return null;
} else {
return 'Enter a valid email';
}
},
),
ElevatedButton(
child: Text(
'Register',
style: TextStyle(color: Colors.white),
),
style: ElevatedButton.styleFrom(
primary: Color(0xFF162242)),
onPressed: () async {
if (_formKey.currentState!.validate()) {
setState(() => loading = true);
dynamic result =
await _auth.registerWithEmailAndPassword(
email, password);
if (result == null) {
setState(() {
error = 'please enter valid email';
loading = false;
});
}
}
}),

等等,我想知道你到底在做什么!

您已经显式地将电子邮件和密码定义为空字符串。

String email = '';
String password = '';
String error = '';

并将这些空字符串传递给_auth.registerWithEmailAndPassword(email, password)?

解决方案是使用TextEditingController对象并从输入字段收集值,然后将它们传递给注册方法。
final emailCtrl =TextEditingController();
final passCtrl = TextEditingController();
...
TextFormField(
controller: emailCtrl,
....
),
TextFormField(
controller: passCtrl,
....
),
...

ElevatedButton(
onPressed: () async {
String email = emailCtrl.text.trim();
String pass = passCtrl.text.trim();
...
dynamic result = await _auth.registerWithEmailAndPassword(email, password);
...
}
)

相关内容

  • 没有找到相关文章

最新更新