一、准备工作
1. 注册微信开放平台账号
地址:([https://open.weixin.qq.com/](https://open.weixin.qq.com/))
2. 申请开发者资质认证:
3. 创建网站应用
4. 查看应用详情,拿到 AppID 、 AppSecret 和 redirect_uri (授权回调域)
二、使用
微信官方文档:关于微信快速登录功能的说明 | 微信开放文档
1. 在index.html
引入微信的js文件 (支持http和https,自行选择)
<script type="text/javascript" src="https://res.wx.qq.com/connect/zh_CN/htmledition/js/wxLogin.js"></script>
2. 在需要使用微信登录的地方实例以下JS对象:
var obj = new WxLogin({self_redirect: false,id:"login_wechat", appid: "", scope: "snsapi_login", redirect_uri: encodeURIComponent("https://www.xxxx.com"),state: Math.ceil(Math.random() * 1000),fast_login: 0
});
3. 获取 code
在PC端打开以下链接
https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
小坑: 如果获取到的code展示在了网址中间(例如:https://www.xxx.com/?code=fjeiwiow&state=52/member/login),那大概率是上一步没配置self_redirect: false。
4. 通过code获取access_token
注:这步需要传密钥,前端直接调用不安全,所以我们是由后端来调用此接口,前端拿返回值进行下一步操作的。
https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
三、完整代码
微信登录页:
<template><div class="qr" id="login_wechat"></div>
</template><script>export default {created(){this.wxSdk(); // 获取展示二维码this.getCode(); // 获取code},watch: {$route(to, from) { // 监听路由,判断网址中是否存在codeif (to.query.code) {// 拿到code做自己的业务逻辑处理 不多赘述}}},methods: {wxSdk() {this.$nextTick(() => {var obj = new WxLogin({self_redirect: false,id: "login_wechat",appid: "wxa1f5ebd09115150a",scope: "snsapi_login",redirect_uri: encodeURIComponent(`https://${window.location.hostname}/#/member/login`),state: Math.ceil(Math.random() * 1000),style: "black",fast_login: 0});})},getCode() {let redirect_uri = encodeURIComponent(`https://${window.location.hostname}/#/member/login`);let state = Math.ceil(Math.random() * 1000);let url = `https://open.weixin.qq.com/connect/qrconnect?appid=wxa1f5ebd09115150a&redirect_uri=${redirect_uri}&response_type=code&scope=snsapi_login&state=${state}#wechat_redirect`;axios.get(url).then(res => { });},}}
</script>