您好我已经按照swift中的电话号码auth教程,这是我的代码:
import UIKit
import FirebaseAuth
class SignInViewController: UIViewController {
@IBOutlet weak var number: UITextField!
override func viewDidLoad() {
super.viewDidLoad()
let myColor : UIColor = UIColor.white
number.layer.borderWidth = 2.0
number.layer.borderColor = myColor.cgColor
number.layer.cornerRadius = 15.0
number.attributedPlaceholder = NSAttributedString(string :"Enter your number", attributes : [NSForegroundColorAttributeName : UIColor.white] )
}
@IBAction func sendCode(_ sender: Any){
let alert = UIAlertController(title: "Phone Number", message: "Is this your phone number? \n \(number.text!)", preferredStyle: .alert)
let action = UIAlertAction(title: "Yes", style: .default) {(UIAlertAction) in
PhoneAuthProvider.provider().verifyPhoneNumber(self.number.text!){ (verificationID, error) in
if error != nil{
print("Error: \(String(describing: error?.localizedDescription))")
}else {
let defaults = UserDefaults.standard
defaults.set(verificationID, forKey: "authVID")
self.performSegue(withIdentifier: "code", sender: Any?.self)
}
}
}
let cancel = UIAlertAction(title: "No", style: .cancel, handler: nil)
alert.addAction(action)
alert.addAction(cancel)
self.present(alert,animated : true, completion : nil)
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}
并验证此代码:
import UIKit
import FirebaseAuth
class VerificationCodeViewController: UIViewController {
@IBOutlet weak var code: UITextField!
override func viewDidLoad() {
super.viewDidLoad()
let myColor : UIColor = UIColor.white
code.layer.borderWidth = 2.0
code.layer.borderColor = myColor.cgColor
code.layer.cornerRadius = 15.0
code.attributedPlaceholder = NSAttributedString(string :"Enter your verification code", attributes : [NSForegroundColorAttributeName : UIColor.white] )
// Do any additional setup after loading the view.
}
@IBAction func verifyCode(_ sender: Any) {
let defaults = UserDefaults.standard
let credential : PhoneAuthCredential = PhoneAuthProvider.provider().credential(withVerificationID: defaults.string(forKey: "authVID")!, verificationCode: code.text!)
Auth.auth().signIn(with: credential) { (user,error) in
if error != nil {
print("error: \(String(describing: error?.localizedDescription))")
}else{
print("Phone number: \(String(describing: user?.phoneNumber))")
let userInfo = user?.providerData[0]
print("Provider ID: \(String(describing: userInfo?.providerID))")
self.performSegue(withIdentifier: "logged", sender: Any?.self)
}
}
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}
我运行我的应用程序我输入数字,但我收到此错误错误:
可选(“令牌不匹配”)
谢谢你的帮助
答案 0 :(得分:4)
请记住,共享构建时使用的证书类型
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
// If you are using the development certificate you have to use this,
Auth.auth().setAPNSToken(deviceToken, type: AuthAPNSTokenType.prod)
// If you are using distribution certificate you should use this
Auth.auth().setAPNSToken(deviceToken, type: AuthAPNSTokenType.sandbox)
// If you want Firebase to automatically detect the type use this.
Auth.auth().setAPNSToken(deviceToken, type: AuthAPNSTokenType.unknown)
}
这很重要,因为在发送推送通知时,URL会在服务器端发生变化。
SANDBOX_ENDPOINT_URL = ' SSL://gateway.sandbox.push.apple.com:2195&#39 ;;常量 SERVICE_ENDPOINT_URL =' ssl://gateway.push.apple.com:2195';
我相信令牌类型将用于选择APNS的URL。
答案 1 :(得分:0)
确保您拥有对数据库的引用。错误是说服务帐户无法识别电话号码。当您使用电话号码注册用户时,您需要更新数据库。
let ref = Database.database().reference(fromURL: "https://MyFireBaseProject.com/")
您可以在数据库控制台中找到您的数据库URL。