欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 青铜选手带你动手撸一个博客小程序给自己(第二期)

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:789

HTML5自适应律师工作室类网

2020-04-04   浏览:654

高端HTML5响应式企业通用网

2020-05-06   浏览:560

html5响应式外贸网站英文版

2020-05-08   浏览:545

HTML5影视传媒文化公司类网

2020-05-12   浏览:543

青铜选手带你动手撸一个博客小程序给自己(第二期)

发布时间:2020-10-03  

小程序登陆逻辑与登陆状态维持的两种姿势

发送评论时的一个投机倒把的小“优化”

小程序微信登陆与前端登陆状态保存 小程序登陆

小程序登陆其实是个比较简单的基本操作,但凡是看过微信开发文档的应该都能懂,不过本菜鸡还是想尝试性的分享一下。

首先先明确一下 为啥要用微信登陆 ,在本菜鸡看来在这个项目里使用微信登陆主要有三个目的

方便用户 :相比于用户手动注册、填写各种信息、再手动输入账号密码登陆,利用微信登陆用户点一下,就可以完成上面的全部操作,注册、登陆全都由后台利用微信提供的相关的信息完成

方便后台用户管理

使用微信的相关能力 :通过微信登陆,后台可以获得唯一标识用户的openid,而这个openid,是后台调用微信相关敏感接口的必填项(例如:微信支付)

然后,明确一下微信登陆过程中的几个概念

青铜选手带你动手撸一个博客小程序给自己(第二期)

然后,结合本次项目的实际情况捋一下微信登陆的流程

调用wx.login方法获取code ,顺手调用一下wx.getUserInfo获取一下用户的基本信息(头像,微信名啥的)

调用后端接口,将code与获取的用户信息userInfo(非必需)传递给后端。

后端接收到参数,将code拿出来与存在后端的appid、appsecrect拼接成微信登陆链接

$url='https://api.weixin.qq.com/sns/jscode2session?appid='.$this->appId.'&secret='.$this->appSecret.'&js_code='.$code.'&grant_type=authorization_code'; 复制代码

访问该链接获得返回结果(json格式的),验证下是否成功,如果OJBK,就从结果里掏出openid

$wxResult=json_decode(curl_get($url),true); if(!$wxResult||!array_key_exists('openid',$wxResult)){ return ResultService::failure('获取openid不成功'); } $openId=$wxResult['openid']; 复制代码

其实获得到openid微信登陆已经差不多了,剩下就是怎么用的问题了,下面的步骤是在本次项目的流程,供各位老哥参考

根据openid查一下数据库,看看是否是存在, 若存在 ,则说明是老用户,不用新增用户,直接用在步骤3中获取到的由前端传来的userInfo更新一下后台的用户信息即可(头像,省份,微信名啥的)。 若不存在 ,则这是个新用户,把openid与userInfo存到用户表中

经过步骤5,库里已经有了这个用户的数据,然后拿用户数据,按照一定规则,生成个token返回给小程序端,小程序端把token存到localStorage里,后端将token与用户信息以键值对的形式存到缓存里,以后小程序请求的时候带着token来,后端根据token查缓存来确定用户登陆状态。

至此,本项目中微信登陆的流程搞完了。登陆完的结果就是,后台新增或更新了用户数据,小程序端有了token。

小程序登陆状态保持

本菜鸡个人觉得常用的保持登陆状态的方法有两种

token(个人推荐)

session

先说第一种,也是本项目采用的方法,其实在上面的步骤5、6已经把这个方法将清楚了,

登陆后服务端下发token给小程序端,

同时服务端自己也存一份,存哪里就根据实际情况(cache、redis、session啥的都行),然后搞个有效期,过期了就消失得那种。

小程序每次请求后端接口的时候把token放到header里

后端在处理请求前先把token从header里取出来,拿这个token去查缓存,如果有,就说明用户还在登陆状态,继续往后走,如果没有,则说明用户离线了,就直接返回一下告诉小程序端需要重新登陆,小程序收到后跳转到登录页。

第二种也在做网站用户登陆的时候是非常常见的操作,在撸网站的时候,用户登陆后把用户信息存到session里,用户在请求的时候能够从session中取到用户信息,之所以这样是因为,浏览器请求服务器,服务器响应时,会带一个sessionid回去给浏览器,浏览器下次请求时候会自动带着sessionid,服务器会根据sessionid来到相应的会话里,所以能取到session中的用户

BUT在小程序中有所不同,这是因为小程序网络访问是用的微信封装的wx.request,而该方法并不会把sessionid存下来,因此,为了能和网站登陆搞成一个逻辑,我们手动存一下sessionid,在下次请求的时候带着sessionid去即可。

部分代码如下

服务端(PHP)

//前面先搞登陆,登陆完了把用户存到session里然后 return ResultService::success('',['sessionId'=>session_id()]); 复制代码 小程序端 //登陆 dataUtils.userLogin({ code: code, info: JSON.stringify(info) }).then(res => { if (res.statusCode == '200') { wx.setStorageSync('sessionId', res.data.data.sessionId); $Message({ content: '登陆成功', type: 'success' }); this.checkUserLogin(); } else { $Message({ content: '登陆未成功', type: 'error' }); } //请求例子(不同后端header名不一样,比如php的后端就是 PHPSESSID=你的sessionId) function userJoinPromise(data,sessionId){ let url = 'travel/api/userJoin'; return getServerDataPromise(url, data, { 'Cookie': 'PHPSESSID=' + sessionId }); }  
复制代码

下班了下班了,先写到这明天继续撸