网站授权微信登录01--PC端

目录

## 前言

1.准备工作

1.1 网站域名

1.2 微信开放平台

2.授权授权登录开发

2.1 前端开发

2.1.1 发起授权登录跳转至扫码页面

2.1.2 扫码成功后回调处理

2.2 后端开发

2.2.1  根据code查询用户信息

2.2.2 自动注册登录

## 后记


## 前言

最近整了个AI助手网站,手机号注册登录时需要填手机号验证码什么的有点麻烦,于是考虑加个微信授权登录。PC端这里实现的效果是点击“微信登录”按钮,然后跳转扫码授权页面,打开手机微信扫码后自动登录网站。开发过程中踩了一些坑这里简单记录下:

1.准备工作

1.1 网站域名

需要有个外网可访问的已备案域名,在微信开放平台申请创建网站应用时使用。

1.2 微信开放平台

需要在微信开放平台注册账号,然后在管理中心-网站应用页面创建网站应用,这里需要填写自己网站的相关信息发起申请,一般1天左右会出结果是否通过。通过之后拿到AppID --前端跳转微信授权时用。

开放平台地址: 微信开放平台

2.授权授权登录开发

2.1 前端开发

2.1.1 发起授权登录跳转至扫码页面

微信登录按钮点击事件:

//微信登录
const wxLogin = function () {
  let protocol = window.location.protocol;
  let host = window.location.host;
  let redirect_uri = protocol + '//' + host + '/login'; //扫码后的回调地址
      let appId = 'xxxxx'; //开放平台AppID
    let wxUrlStart = 'https://open.weixin.qq.com/connect/qrconnect?appid=' + appId + '&redirect_uri=';
    let wxUrlEnd = '&response_type=code&scope=snsapi_login&state=STATE#wechat_redirect';
    let allUrl = wxUrlStart + encodeURIComponent(redirect_uri) + wxUrlEnd;
    window.location.replace(allUrl);
}

2.1.2 扫码成功后回调处理

扫码成功后会自动跳转至自定义的回调地址redirect_uri,并带上开放平台返回的code,拿到这个code去后台查询用户信息进行后续自动注册登录操作。

//获取微信授权重定向后的code
  let code = getUrlParam('code');
  if (code) {
    //微信授权自动注册登录
       httpPost('/api/user/wxLogin', {code: code}).then((res) => {
      setUserToken(res.data)
      router.push('/chat')
   }).catch((e) => {
      ElMessage.error('登录失败,' + e.message)
    })
  } 

//页面重定向获取URL中参数值
const getUrlParam = function(queryName) {
    const queryString = window.location.search;
    const params = new URLSearchParams(queryString);
    const value = params.get(queryName);
    return value ? decodeURIComponent(value) : null;
}

2.2 后端开发

2.2.1  根据code查询用户信息

先拿code获取AccessToken,再拿AccessToken获取用户的openid、昵称等信息,其中openid是用户唯一标识,可以拿来注册登录用。

需要用到的接口地址:

获取AccessToken:https://api.weixin.qq.com/sns/oauth2/access_token

获取用户信息:https://api.weixin.qq.com/sns/userinfo

具体代码开发可参考官方接口文档:网站应用微信登录开发指南

2.2.2 自动注册登录

拿到用户openid后即可作为用户唯一标识进行注册登录操作。

## 后记

至此开发工作已完成,在域名对应的服务器上部署启动项目,测试功能OK即可。

最后提一下自己的小站(支持微信登录),提供了chatGPT等多种AI对话及MJ绘画功能。

体验地址:https://ai.xiaomaicoder.com/login,欢迎体验交流!

  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值