尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

通过授权获取用户 open_id

通过授权获取用户 open_id
📅 发布时间:2026/6/19 21:14:40

静默授权获取openid确实主要是前端页面操作,后端只需处理最后一步的code换openid。具体流程如下:

完整操作流程

第一步:微信公众号后台配置(管理员操作)

  1. 配置授权回调域名

    • 登录公众平台 → 设置与开发 → 公众号设置 → 功能设置

    • 找到网页授权域名设置项

    • 填写你的域名(不要加http://,如yourdomain.com)

  2. 上传校验文件

    • 点击下载微信提供的TXT验证文件(如MP_verify_xxxxxx.txt)

    • 将该文件上传至服务器根目录(确保能访问http://yourdomain.com/MP_verify_xxxxxx.txt)

    • 保存配置,等待审核通过

第二步:前端实现静默授权(核心操作)

整个授权流程需要在微信浏览器内完成。

1. 准备结果页面

创建一个授权回调页面(如/auth/callback),用于接收微信返回的code:

HTML

预览

复制

<!-- callback.html --> <!DOCTYPE html> <html> <head> <title>授权中...</title> </head> <body> <script> // 页面加载时获取code function getCode() { const url = window.location.href; const code = url.split('code=')[1]?.split('&')[0]; if (code) { // 将code传给后端 fetch('/api/getOpenid', { method: 'POST', body: JSON.stringify({ code }) }).then(res => { // 处理成功后的逻辑,如跳转到目标页面 window.location.href = '/home'; }); } else { alert('授权失败,请重试'); } } getCode(); </script> </body> </html>
2. 构造授权URL并跳转

在用户需要获取openid时(如点击"绑定微信"按钮),前端构造授权链接并跳转:

JavaScript

复制

// 对回调地址进行URL编码 function urlencode(str) { return encodeURIComponent(str) .replace(/!/g, '%21') .replace(/'/g, '%27') .replace(/\(/g, '%28') .replace(/\)/g, '%29') .replace(/\*/g, '%2A') .replace(/%20/g, '+'); } // 获取openid的函数 function getWechatOpenid() { const appid = 'YOUR_APPID'; // 公众号AppID const redirectUri = urlencode('https://yourdomain.com/auth/callback'); // 结果页面地址 const scope = 'snsapi_base'; // 静默授权 const state = '123'; // 可选,用于传递自定义参数 const authUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${redirectUri}&response_type=code&scope=${scope}&state=${state}#wechat_redirect`; // 如果是微信浏览器内,直接跳转 if (isWechatBrowser()) { window.location.href = authUrl; } else { // 非微信环境:生成二维码或提示复制链接 alert('请使用微信扫一扫或复制链接到微信打开'); } } // 判断是否为微信浏览器 function isWechatBrowser() { return /MicroMessenger/i.test(navigator.userAgent); }
3. 触发授权

在页面中添加触发按钮:

HTML

预览

复制

<button onclick="getWechatOpenid()">绑定微信</button>

第三步:后端处理code换取openid

前端获取到code后,需由后端服务器调用微信接口换取openid:

java

复制

// Java示例 public String getOpenId(String code) { String url = "https://api.weixin.qq.com/sns/oauth2/access_token?" + "appid=APPID&secret=APPSECRET&code=" + code + "&grant_type=authorization_code"; // 发起HTTP GET请求 String result = restTemplate.getForObject(url, String.class); JSONObject json = JSON.parseObject(result); return json.getString("openid"); // 返回openid }

关键参数:

  • APPID:公众号AppID

  • APPSECRET:公众号AppSecret

  • code:前端传来的临时凭证(有效期5分钟,只能使用一次)

重要注意事项

1.域名必须完全一致

  • 配置的授权域名必须与redirect_uri的域名完全一致

  • 不支持子域名通配,如需多个域名需分别配置

2.URL编码要求

  • redirect_uri必须经过严格URL编码,否则微信会提示"redirect_uri参数错误"

  • 如果回调地址包含hash路由(如/#/pages/bind),需对整个URL编码

3.环境判断

  • 必须在微信内置浏览器中打开授权链接

  • PC端可将链接生成二维码,引导用户微信扫码

4.静默授权特点

  • scope=snsapi_base时,用户无感知,页面直接跳转

  • 只能获取openid,无法获取昵称、头像等信息

  • 用户无需关注公众号也可获取openid

5.Token管理

  • 返回的access_token与普通access_token不同,无需缓存

  • 此token仅用于获取用户信息,2小时有效期,不限制调用次数

常见问题排查

表格

复制

问题原因解决方案
redirect_uri参数错误域名未配置或URL编码不正确检查授权域名配置,重新编码回调地址
无法获取code在非微信浏览器打开确保在微信内访问,或使用二维码引导
提示scope参数错误或没有scope权限使用了snsapi_userinfo但未认证服务号需微信认证后才可使用userinfo
code已失效code超过5分钟或已被使用重新发起授权流程

整个流程核心是前端负责跳转和获取code,后端负责换取openid,分工明确且安全。

相关新闻

  • 科研起航“智囊团”:书匠策AI开题报告功能,开启学术探索新纪元
  • Open-AutoGLM日志加密部署难题:90%团队忽略的2个致命风险点
  • LangFlow服务器响应时间缩短方法

最新新闻

  • 微信防撤回失效?RevokeMsgPatcher 2.0 技术原理与实战指南
  • 普宁连锁眼镜店哪家靠谱|自营和加盟的本质区别是什么 - 品牌观察
  • 普宁本地人常去的眼镜店|口碑最好的门店是怎么来的 - 品牌观察
  • MC9S12XE内存映射控制(MMC)详解:模式、分页与实战配置
  • 【2026年6月】自吸离心泵厂家推荐 - 多才菠萝
  • 普宁眼镜店哪家好|怎么判断本地眼镜店靠不靠谱 - 品牌观察

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号