挪用接口获取登录凭证(code)进而换取用户登录态信息,,,包括用户的唯一标识(openid) 及本次登录的 会话密钥(session_key)。。。。。用户数据的加解密通讯需要依赖会话密钥完成。。。。。
OBJECT参数说明:
| 参数名 | 类型 | 必填 | 说明 |
|---|---|---|---|
| success | Function | 否 | 接口挪用乐成的回调函数 |
| fail | Function | 否 | 接口挪用失败的回调函数 |
| complete | Function | 否 | 接口挪用竣事的回调函数(挪用乐成、失败都会执行) |
success返回参数说明:
| 参数名 | 类型 | 说明 |
|---|---|---|
| errMsg | String | 挪用效果 |
| code | String |
用户允许登录后,,,回调内容会带上 code(有用期五分钟),,,开发者需要将 code 发送到开发者服务器后台,,,使用code 换取 session_key api,,,将 code 换成 openid 和 session_key |
示例代码:
//app.js
App({
onLaunch: function() {
wx.login({
success: function(res) {
if (res.code) {
//提倡网络请求
wx.request({
url: 'https://test.com/onLogin',
data: {
code: res.code
}
})
} else {
console.log('获取用户登录态失败!' + res.errMsg)
}
}
});
}
})
?这是一个 HTTPS 接口,,,开发者服务器使用登录凭证 code 获取 session_key 和 openid。。。。。其中 session_key 是对用户数据举行加密署名的密钥。。。。。为了自身应用清静,,,session_key 不应该在网络上传输。。。。。
接口地点:
https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code
请求参数:
| 参数 | 必填 | 说明 |
|---|---|---|
| appid | 是 | 小程序唯一标识 |
| secret | 是 | 小程序的 app secret |
| js_code | 是 | 登录时获取的 code |
| grant_type | 是 | 填写为 authorization_code |
返回参数:
| 参数 | 说明 |
|---|---|
| openid | 用户唯一标识 |
| session_key | 会话密钥 |
| unionid | 用户在开放平台的唯一标识符。。。。。本字段在知足一定条件的情形下才返回。。。。。详细参看UnionID机制说明 |
返回说明:
//正常返回的JSON数据包
{
"openid": "OPENID",
"session_key": "SESSIONKEY"
"unionid": "UNIONID"
}
//过失时返回JSON数据包(示例为Code无效)
{
"errcode": 40029,
"errmsg": "invalid code"
}
通过上述接口获得的用户登录态拥有一定的时效性。。。。。用户越久未使用小程序,,,用户登录态越有可能失效。。。。。反之若是用户一直在使用小程序,,,则用户登录态一直坚持有用。。。。。详细时效逻辑由微信维护,,,对开发者透明。。。。???⒄咧恍枰灿脀x.checkSession接口检测目今用户登录态是否有用。。。。。登录态逾期后开发者可以再挪用wx.login获取新的用户登录态。。。。。
OBJECT参数说明:
| 参数名 | 类型 | 必填 | 说明 |
|---|---|---|---|
| success | Function | 否 | 接口挪用乐成的回调函数,,,登陆态未逾期 |
| fail | Function | 否 | 接口挪用失败的回调函数,,,登陆态已逾期 |
| complete | Function | 否 | 接口挪用竣事的回调函数(挪用乐成、失败都会执行) |
示例代码:
wx.checkSession({
success: function(){
//session 未逾期,,,并且在本生命周期一直有用
},
fail: function(){
//登录态逾期
wx.login() //重新登录 ....
}
})
通过wx.login()获取到用户登录态之后,,,需要维护登录态。。。。???⒄咭⒅不应该直接把 session_key、openid 等字段作为用户的标识或者 session 的标识,,,而应该自己派发一个 session 登录态(请参考登录时序图)。。。。。关于开发者自己天生的 session,,,应该包管其清静性且不应该设置较长的逾期时间。。。。。session 派发到小程序客户端之后,,,可将其存储在 storage ,,,用于后续通讯使用。。。。。
通过wx.checkSession()检测用户登录态是否失效。。。。。并决议是否挪用wx.login() 重新获取登录态
bug: iOS/Android 6.3.30,,,在 App.onLaunch 挪用 wx.login 会泛起异常;;;;;;KESION pp电子软件
KESION pp电子软件是海内领先的在线教育软件及私域社交电商软件服务提供商,,,恒久专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。。。。。
公司焦点产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化自力安排品牌网校和在线教育咨询等。。。。。KESION 一直通过手艺立异,,,提供产品和服务,,,助力企业向数字化转型,,,通过科技驱动商业刷新,,,让商业变得更智慧!
微信小程序使用CSS3字体是在小程序开发中添加外部字体,,,那么要怎样实现呢。。。。。...
小程序的火力上线,,,也让许多商城有了自己的小程序,,,商城有种种各样的商品,,,以是在小程序开发时需要设置左侧栏分类,,,这个分类页面可以给用户快速找到相关的商品。。。。。...