==用户登录==是微信小程序必不可少的环节,一个完整的登录功能还包括用户的信息获取、登录的状态判定等。下图为未登录和已登录页面效果图。
小程序通过微信官方提供的,获取微信提登录能力供的用户身份标识,建立用户体系。==用户登录流程==时序图(下图所示):
(资料图片)
用户登录流程需要小程序、开发者服务器和微信接口服务3个角色的参与,
下面介绍这3个角色的==作用==:
登录流程==具体细节==:
小程序获取code。小程序将code发送给开发者服务器。开发者服务器通过微信接口服务校验登录凭证。开发者服务器自定义登录态。==数据缓存==:缓存数据,从而在小程序退出后再次打开时,可以从缓存中读取上次保存的数据,常用的==数据缓存API==如下表所示:
保存数据缓存示例代码如下:
获取缓存数据示例代码如下:
本节选择使用Node.js搭建开发者服务器,安装Node.js,==创建项目==:
初始化项目,将会自动创建package.json配置文件。安装Express框架和request模块。安装nodemon监控文件修改(如果已经安装则跳过此步)。执行上述命令后,在项目目录下创建==index.js==文件,编写代码如下:
引入Express框架和request模块,配置appid和secret。模拟数据库。请求登录接口,校验登录凭证的微信接口URL地址。处理判断语句代码。暴露对外访问接口地址。保存上述代码后,执行如下命令,启动开发者服务器。
创建一个空白项目,在app.js文件中编写代码,实现小程序启动时自动执行登录操作。
请求login登录接口。
执行上述代码,控制台中打印出login code和token的值。
在开发者服务器的控制台中,打印出login code和session的值。
==注意==:
判断数据缓存中是否存在token如果存在,取出数据缓存中的token值,不用再执行登录操作。需要注意的是,token有可能会过期,需要重新登录,这就需要从数据缓存中取出token后,先验证token是否过期,再使用token。
进入app.js中编写checkLogin()函数,判断token是否存在。
如果token存在,判断token是否有效。
修改app.js中onLaunch()函数,用于在小程序启动后检查用户是否已经登录,如果没有登录则执行登录操作。
==获取用户信息==的两种常用方式如下:
使用< open-data>组件的方式。单击按钮提示授权的方式。使用< open-data>组件来获取==使用场景==:开发者服务器想要获取用户信息,需要在小程序端通过
wx.request()请求来获取。
==使用弊端==:无法辨别数据的真伪。
==解决办法==:利用小程序提供的开放数据的校验和解密机制。
个人中心案例设计了两个标签页,“首页”展示个人的基本信息及简单的自我介绍;“个人中心”底部标签页==任务需求==如下:
==展示个人资料==:展示头像、昵称、性别等信息。
==订单物流查询==:输入订单号和快递公司查询物流信息。
==选择收货地址==:调用开放接口,访问系统收货地址,进行选择。
==客服联系电话==:调用开放接口, 访问通讯录,拨打客服电话。
同时设计两个标签页,通过这两个标签页来实现页面之间的跳转。
==任务需求==如下:
页面效果图:
在“首页”中单击头像上方提示语“点我跳转”,进入到 “个人中心页面”;这两个页面都属于tabBar页面,所以使用wx.swichTab或者wx.reLaunch方式。
在app.js文件,配置tabBar在index.wxml文件,为头像绑定changeImage()函数在index.js文件,编写changeImage()函数在本任务中,将会实现订单物流查询功能,在“个人中心”页单击“订单物流查询”跳转到 pages/order/order“订单查询”页面。
==功能需求==如下:
在本任务中,将会实现选择收货地址功能,在“个人中心”页单击“选择收货地址”跳转到 pages/address/address “收货地址”页面。
==功能需求==如下:
在本任务中,将会实现拨打电话功能。
==功能需求==如下:
天气查询小程序,可以查询今日的天气状况,实时温度等信息。
==功能需求==如下:
wx.request 发起HTTPS网络请求,一个小程序,同时只能有5个网络请求连接
该案例使用腾讯地图SDK,配合地图组件和API进行调用,实现查看附近的美食餐厅小程序。
==功能需求==如下:
页面效果图:
本章介绍了微信小程序中的API功能,包括使用小程序开放接口获取用户的信息、授权登录、添加用户收货地址,调起相机、相册选择图片等,同时也使用腾讯地图插件SDK定位附近的美食餐厅。根据POST和GET两种请求方式,介绍了不同数据类型之间的转换规则。学习本章后,读者需要掌握小程序中常用的API方法,熟练地进行与服务器的数据交互,实现项目产品需求。