🎉🚀React封装 微信扫码 登录组件

我们经常遇到这种网站,像csdn就是这样,扫一个码去关注公众号,得到 你的微信的、在这个公众号的、唯一的openid作为标识符,去进入网站。

这样做的好处就是做私域运营的话,增长了粉丝又区分了粉丝,又登录到位了、阻隔了闲杂人等。

二维码渲染

获取二维码阶段:后端向微信服务器请求获取临时二维码(包含唯一标识和图片数据),前端将base64格式的二维码图片展示给用户。

后端nodejs来实现,大概代码如下:

js 复制代码
// 用这个库去发http请求
const axios = require('axios');

// 取微信二维码,然后返回去给前端用
async function getWechatQRCode() {
  const response = await axios.get('https://api.weixin.qq.com/sns/qrcode/create', {
    params: {
      appid: '微信应用的唯一标识(用公众号的appid)',
      redirect_uri: '授权后的回调地址(用扫码授权后的回调地址)',
      scope: 'snsapi_login',
      state: '随机值(用来防止csrf的)'
    }
  });
  
  return {
    ticket: response.data.ticket, // 二维码唯一标识
    qrUrl: response.data.base64     // 二维码图片base64
  };
}

前端去拿二维码,渲染到页面上:

js 复制代码
// React组件示例------登录页(代码如下所示)
const [qrCode, setQrCode] = useState('');
const [ticket, setTicket] = useState('');

useEffect(() => {
  const fetchQRCode = async () => {
    const response = await fetch('/api/wechat/qrcode'); // 调后端的获取二维码接口
    const data = await response.json();
    setQrCode(data.qrUrl); // 获取二维码渲染到页面
    setTicket(data.ticket); // 设置唯一值
  };
  
  fetchQRCode();
}, []);

轮询检查

扫码确认阶段:用户扫码后,微信服务器会通知我们的后端服务,前端通过轮询或长连接不断检查扫码状态。

js 复制代码
// waiting, scanned, confirmed, expired
const [scanStatus, setScanStatus] = useState('waiting'); 

useEffect(() => {
  const intervalId = setInterval(async () => {
    const response = await fetch(`/api/wechat/check-status?ticket=${ticket}`);
    const { status, userInfo } = await response.json();
    
    setScanStatus(status);
    
    if (status === 'confirmed') {
      clearInterval(intervalId);
      handleLoginSuccess(userInfo); // 执行成功回调
    }
  }, 1000); // 每1秒检查一次

  return () => clearInterval(intervalId);
}, [ticket]);

登录完成阶段:当前端检测到用户已扫码确认,触发登录成功流程,跳转或更新用户状态

js 复制代码
const handleLoginSuccess = (userInfo) => {
  setUser(userInfo);
  localStorage.setItem('token', userInfo.token);
  navigate('/dashboard');
};

封装扫码组件

这里讲一下为啥要封这个微信扫码组件?

第一点 ,一般作为后台的扫码登录入口;
第二点 ,比如说用户换绑关联更新用户信息;
第三点,一般要用扫码登录去获取用户信息的地方。

所以就封装成一个组件,用的时候引用就好了。

通用性设计

将微信扫码功能封装为独立React组件时,关键在于保持高度通用性。组件不应只服务于登录场景,而应该适用于:

  • 用户登录
  • 账号绑定
  • 身份验证
  • 任何需要微信用户确认的场景

回调机制

通过onSuccess等回调函数将业务逻辑与组件解耦:

jsx 复制代码
<WechatQRLogin 
  onSuccess={(userData) => {
    // 登录成功处理
    // 可以是跳转、更新状态等
  }}
  onError={(error) => {
    // 错误处理
  }}
/>

内置状态管理

组件内部应处理好以下状态:

  • 二维码获取与刷新
  • 轮询检查扫码状态
  • 超时处理
  • 错误重试机制

二维码刷新策略

实现自动刷新机制,当二维码过期时:

js 复制代码
const refreshQR = () => {
  // 重新获取二维码逻辑
  // 通常设置定时器在二维码快过期时自动刷新
}

样式可定制化

通过props允许外部控制样式:

jsx 复制代码
<WechatQRLogin 
  qrStyle={{ width: 200, height: 200 }}
  refreshBtnStyle={{ color: '#1890ff' }}
/>

总结

这个组件要做得简单好用,微信登录流程归它管,业务逻辑交给外面的回调处理,别混在一起。各种出错情况都得考虑到,比如网络问题、超时或者用户中途取消,不能动不动就崩了。

轮询频率要合理,别太频繁,省得浪费资源。用 TypeScript 写好类型定义,让调用的时候有提示,少踩坑。最后文档得写清楚,少讲概念,多给例子,让人一看就知道怎么用。

通过这种封装方式,我们可以在任何需要微信扫码的场景中快速复用该组件,只需关注业务逻辑处理,提高了开发效率和代码质量。

相关推荐
天人合一peng28 分钟前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling1 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区2 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO2 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121382 小时前
Vuex介绍
前端·javascript·vue.js
We་ct2 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480063 小时前
【无标题】
开发语言·前端·javascript
css趣多多3 小时前
Vue过滤器
前端·javascript·vue.js
理人综艺好会3 小时前
Web学习之用户认证
前端·学习