第三方登录模块使开发者能快捷灵活的拥有自己的用户系统,是 LeanCloud 最受欢迎的功能之一。随着第三方平台的演化,特别是微信小程序的流行,LeanCloud 第三方登录模块也一直在改进:
- v2.0*:增加微信小程序一键登录功能。支持开发者不写任何后端代码实现微信小程序用户系统与 LeanCloud 用户系统的关联。
- v3.6:增加 unionid 登录接口。支持开发者使用 unionid 关联一个微信开发者帐号下的多个应用从而共享一套 LeanCloud 用户系统。
这两个功能各自都非常简单可靠,但是其中重叠的部分需求却是一个难题:「如何在小程序中支持 unionid 登录,既能得到 unionid 登录机制的灵活性,又保留一键登录功能的便利性」。
在最近发布的 JavaScript SDK v3.13 中包含了微信小程序 unionid 登录支持。我们根据不同的需求设计了不同的解决方案。
* 这里的版本指开始支持该功能的 JavaScript SDK 版本。
一键登录
LeanCloud 的用户系统支持一键使用微信用户身份登录。要使用一键登录功能,需要先设置小程序的 AppID 与 AppSecret:
1.登录 微信公众平台,在 设置 > 开发设置 中获得 AppID 与 AppSecret。
前往 LeanCloud 控制台 > 组件 > 社交,保存「微信小程序」的 AppID 与 AppSecret。
这样你就可以在应用中使用AV.User.loginWithWeapp()
方法来使用当前用户身份登录了。
AV.User.loginWithWeapp().then(user => {
this.globalData.user = user;
}).catch(console.error);
使用一键登录方式登录时,LeanCloud 会将该用户的小程序 openid
与 session_key
等信息保存在对应的 user.authData.lc_weapp
属性中,你可以在控制台的 _User
表中看到:
{
"authData": {
"lc_weapp": {
"session_key": "2zIDoEEUhkb0B5pUTzsLVg==",
"expires_in": 7200,
"openid": "obznq0GuHPxdRYaaDkPOHk785DuA"
}
}
}
如果用户是第一次使用此应用,调用登录 API 会创建一个新的用户,你可以在 控制台 > 存储 中的 _User
表中看到该用户的信息,如果用户曾经使用该方式登录过此应用(存在对应 openid 的用户),再次调用登录 API 会返回同一个用户。
用户的登录状态会保存在客户端中,可以使用 AV.User.current()
方法来获取当前登录的用户,下面的例子展示了如何为登录用户保存额外的信息:
// 假设已经通过 AV.User.loginWithWeapp() 登录
// 获得当前登录用户
const user = AV.User.current();
// 调用小程序 API,得到用户信息
wx.getUserInfo({
success: ({userInfo}) => {
// 更新当前用户的信息
user.set(userInfo).save().then