所谓SSO就是一个地方登录,多个系统或者多个应用自动识别身份免密登录进去。实际是得到一个用户flag(uid)。
它能做什么事呢?比如我们有两个互不相关的应用A和B,我们在应用A登录了之后,进入应用B会自动识别身份不再输入账密就登录进去了。
详情自查不再累述
这里我们用Firebase来做身份识别,相当简单。
第一步
https://console.firebase.google.com/
去FireBase官网注册一个项目,有文档可查,然后再注册一个应用,输入Bundle ID。
此时会有个GoogleService-Info.plist的文件需要你下载下来,这个文件里有你项目和应用的信息。
将此文件放入根目录:
第二步
cocopods导入SDK
pod 'Firebase/Analytics'
pod 'Firebase/Auth'
第三步
AppDelegate文件里didFinishLaunchingWithOptions方法下面加入FirebaseApp.configure()
先import Firebase
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
FirebaseApp.configure()
return true
}
第四步
使用api,最重要的就是添加监听,只要有用户身份信息就会立即响应,如果你已经登陆过了,那么下次进入应用这个block会立即回调给你用户信息
override func viewWillAppear(_ animated: Bool) {
// 添加监听,只要有用户身份信息就会立即响应,如果你已经登陆过了,那么下次进入应用这个block会立即回调给你用户信息
handle = Auth.auth().addStateDidChangeListener { (auth, user) in
if let user = user {
let uid = user.uid
let email = user.email
let photoURL = user.photoURL
print("uid: \(uid) email: \(email) photoURL: \(photoURL)") // 获取到用户信息就是识别成功了
}
}
}
@IBAction func loginClicked(_ sender: Any) {
let emailStr = emailTF.text ?? ""
let pwStr = pwTF.text ?? ""
// 用email和password登陆
Auth.auth().signIn(withEmail: emailStr, password: pwStr) { [weak self] authResult, error in
guard let strongSelf = self else { return }
}
}
@IBAction func registerClicked(_ sender: Any) {
let emailStr = emailTF.text ?? ""
let pwStr = pwTF.text ?? ""
// 新建一个用户
Auth.auth().createUser(withEmail: emailStr, password: pwStr) { [weak self] authResult, error in
guard let strongSelf = self else { return }
}
}
override func viewWillDisappear(_ animated: Bool) {
// 取消监听
Auth.auth().removeStateDidChangeListener(handle!)
}
完成上面这些步骤之后就已经集成了SSO的身份识别功能了
你也可以到Firebase的控制台管理你的用户