建设网站公司名称大全,网站系统目前运行稳定,网站服务公司有哪些,网页游戏网站快手这是微信官方提供的时序图。我们需要关注的是前后端的交互#xff0c;以及服务端如何收发网络请求。
小程序端
封装基本网络请求
我们先封装一个基本的网络请求。
const baseUrllocalhost:8080
export default{sendRequsetAsync
}
/* e
url#xff1a;目标页…这是微信官方提供的时序图。我们需要关注的是前后端的交互以及服务端如何收发网络请求。
小程序端
封装基本网络请求
我们先封装一个基本的网络请求。
const baseUrllocalhost:8080
export default{sendRequsetAsync
}
/* e
url目标页面带斜杠/user
method:方法默认GET
data:json格式的数据
*/
async function sendRequsetAsync(e) {let responseconsole.log(发送异步网络请求)console.log(e)let promise await new Promise((resolve, reject) {wx.request({url: baseUrl e.url,method: e.method || GET,data: e.data || {},success: (res) {resolve(res)},fail: (error) {reject(error)}})})console.log(promise);return promise
}
指定baseUrl为本地8080端口。之后所有的小程序网络请求都基于这个方法。 这样当服务端地址变更时只需要修改这里的baseUrl而不需要对每个涉及网络请求的js文件都作修改。 使用promise获取服务端返回的数据。直接接受wx.request()的返回值得到的是一个网络请求任务对象。 赋值采用的是JS特有的括号()方法。如果用等号可能会赋值失败。 如果没有await创建对象直接直接输出得到的是一个promise对象。 这是因为promise是一个异步请求对象。在执行结束前设计的数据会随时变动。 如果要等待异步请求结束查看最终结算则需要加上await。 方法内使用await的前提是方法外使用async。
实现小程序登录
我们已经封装了基本的网络请求根据微信官方提供的时序图我们接下来需要获取用户登录授权码code。 调用wx.login()方法可以直接获取 wx.login()会弹出提示请求用户授权这也是一个异步请求如果要等接收到用户反馈之后再执行下一步操作也需要添加await。
let loginResultLocal await wx.login()
console.log(loginResultLocal)
if (loginResultLocal.errMsg login:ok) {//本地请求登录获取codelet loginResultServer await loginByCode(loginResultLocal.code)//尝试通过code登陆if (loginResultServer.state 0) {//用户未注册console.log(用户未注册)} else if (loginResultServer.state 1) {//用户已注册console.log(用户已注册);}
} else {//如果用户不同意登录跳转到拒绝服务页面直到同意wx.reLaunch({url: /pages/user/userRegister/userRegister})
}当然这段代码也需要封装进工具类中也需要调用之前封装好的其他工具类。 导入其他工具类只需要这一行代码照葫芦画瓢即可import webRequest from ./webRequest.js; 现在已经获取到了code也封装了基本网络请求。接下来需要实现登陆方法将小程序端获取到的code发送到服务端接收服务端返回的openid等信息。 现在我们还没介绍服务端的业务逻辑无论发送什么内容返回数据都是“收到”。
async function loginByCode(code) {//通过code登录console.log(通过code登录code);let e {url: /user/user/login,method: POST,data: {loginMethod: code,code: code}}let requestResult await webRequest.sendRequsetAsync(e)return requestResult
}控制台输出 服务端好像收到了小程序端发送到数据但服务端接受的实际内容、服务端的业务逻辑我们目前还是不清楚的。
服务端
小程序端以json形式以POST方法发送了用户凭证code。 openid需要从服务端通过GET方法获取 可以得出服务端应能够
解析json响应post方法发送get请求
解析JSON响应POST方法 根据开发文档我们需要提前准备好appid和secret。如果不知道在哪里可以直接私我。 按照上面的格式添加到配置文件中。 这并没有通过全局静态常量的方式保存在类中。因为小程序信息可能会经常用到之后也可能会发生改变通过引用的方式可以只修改这一处。
Value(${wechat.appid})
private String appid;
Value(${wechat.secret})
private String secret;通过Value注解将配置文件中的值赋值给下面的字符串。 GET方法的参数暴露在Url中可以选择用简单粗暴的字符串拼接方式发送GET请求。 服务端发送登录请求还需要code这由小程序端通过POST请求传入。 可以提前创建实体类。 public class UserLoginDTO {Getterprivate String code;
}响应POST请求通过PostMapping注解实现 解析POST请求携带的JSON作为函数参数传入通过RequestBody注解实现
HttpClient
HttpClient工具包用于在spring中发送网络请求。 https://hc.apache.org/httpcomponents-client-5.2.x/quickstart.html 发送请求步骤
创建HttpClient对象创建Http请求对象调用HttpClient的execute方法发送请求
//创建HttpClient对象
CloseableHttpClient httpClient HttpClients.createDefault();
//创建请求对象
HttpGet httpGet new HttpGet(https://api.weixin.qq.com/sns/jscode2session?appid appid secret secret js_code userLoginDTO.getCode() grant_typeauthorization_code);
//发送请求接受响应结果
CloseableHttpResponse response httpClient.execute(httpGet); //获取服务端返回的状态码
if (response.getCode() 200) {//获取服务端返回的数据HttpEntity entity response.getEntity();String body EntityUtils.toString(entity);System.out.println(body);//关闭资源response.close();httpClient.close();return body;
}Api测试
回到小程序端。服务端返回的消息随着软件开发的完善可能会作出修改。将相关代码单独封装。 目前输出结果如下 可以通过wx.getStorageSync和wx.setStorageSync方法把openid和会话密钥在用户本地存取。