最近小程序特别火,所以我们公司也针对ecshop平台对接了小程序
包括完整的用户系统和购物体统
用户系统:收货地址,订单管理,消息管理,优惠券管理等等
购物系统支付购物车管理,微信支付等等
相信有很多小伙伴都用的是ecshop作为自己的商城,最近小程序又火了,于是就有人问ecshop对接小程序怎么做。
正好最近在开发一个对接ecshop的小程序项目,就将我的一些开发经验分享一下。
一:扫描小程序二维码后的用户信息的获取和缓存
获取用户信息需要用到两个api
调用接口获取登录凭证(code)进而换取用户登录态信息,包括用户的唯一标识(openid) 及本次登录的 会话密钥(session_key)。用户数据的加解密通讯需要依赖会话密钥完成。
获取用户信息,需要先调用 wx.login 接口。
获取缓存需要用到的api
将 data 存储在本地缓存中指定的 key 中,会覆盖掉原来该 key 对应的内容,这是一个同步接口。
下面就是具体实例代码:
我们可以将这段写在公共的app.js页面
0){
//缓存user_id
wx.setStorageSync('scuserid',scuserid)
wx.setStorageSync('openid',res.data.openid)
wx.setStorageSync('sc_session_id',res.data.session_id)
}
}else{
//缓存session_id
wx.setStorageSync('openid',res.data.openid)
wx.setStorageSync('sc_session_id',res.data.session_id)
//获取用户信息
wx.getUserInfo({
success: function (res) {
that.globalData.userInfo = res.userInfo
typeof cb == "function" && cb(that.globalData.userInfo)
//console.log(res);
wx.request({
url: 'xxxx/data.php?action=saveUserInfo',data: {
userinfo: res.userInfo,openid: wx.getStorageSync('openid'),success: function (res) {
//console.log(res.data)
var status = res.data.status
if(status == 1){
wx.showToast({
title: res.data.message,duration: 2000
})
}else{
var scuserid = res.data.userid
if(scuserid > 0){
//缓存user_id
wx.setStorageSync('scuserid',scuserid)
}
}
}
})
}
})
}
}
})
}
}
}
})
}
},globalData: {
userInfo: null
}
})
二:获取微信用户的信息以及如何将用户信息缓存起来
要获取用户的地理信息则要用到
获取当前的地理位置、速度。当用户离开小程序后,此接口无法调用;当用户点击“显示在聊天顶部”时,此接口可继续调用。
具体实例代码:
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|