ios - 当前用户属性更改的 Firebase 监听器
<p><p>我想根据 Firebase currentUser 参数 isEmailVerified 的更改来关闭 ViewController。基本上,如果用户登录到应用程序并且没有验证她的电子邮件,则会显示这个 VC,我的计划是让它一直留在那里直到她验证它,在这种情况下,Firebase 会自动将 isEmailVerified 设置为 true,并且 VC 应该被解雇。到目前为止,我已经附加了一个监听器来识别 currentUser 的变化,但它似乎不起作用。我做错了什么?</p>
<pre><code>override func viewDidLoad() {
super.viewDidLoad()
// Create listener
let _ = Auth.auth().addStateDidChangeListener { (auth, user) in
if user?.isEmailVerified == true {
self.presentingViewController?.dismiss(animated: true, completion: nil)
}
}
}
</code></pre></p>
<br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
<p><pre><code>[ signInWithEmail:emailTxt.text
password:pwdStr
completion:^(FIRUser *user, NSError *error) {
if(error == nil){
if (user.isEmailVerified) {
//present different VC
// if user is not isEmailVerifiedis not true show alert to user
please verify email in order to proceed
}
} withCancelBlock:^(NSError * _Nonnull error) {
// dismiss view
}];
</code></pre>
<p>在这里您可以看到用户的电子邮件验证状态,并根据显示 ViewController 或什么都不做</p>
<p>否则,在上述方法之后,在电子邮件验证的 else 条件中使用计时器方法来触发以下方法并检查用户验证的电子邮件是否</p>
<pre><code>func checkIfTheEmailIsVerified(){
FIRAuth.auth()?.currentUser?.reload(completion: { (err) in
if err == nil{
if FIRAuth.auth()!.currentUser!.isEmailVerified{
// Your code
} else {
print("It aint verified yet")
}
} else {
print(err?.localizedDescription)
}
})
}
</code></pre></p>
<p style="font-size: 20px;">关于ios - 当前用户属性更改的 Firebase 监听器,我们在Stack Overflow上找到一个类似的问题:
<a href="https://stackoverflow.com/questions/45882865/" rel="noreferrer noopener nofollow" style="color: red;">
https://stackoverflow.com/questions/45882865/
</a>
</p>
页:
[1]