news 2026/4/15 14:41:47

通过授权获取用户 open_id

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
通过授权获取用户 open_id

静默授权获取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,分工明确且安全。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 15:20:31

C++使用rand生成随机数

产生 [0,b] 之间的随机数&#xff1a; rand()*b / RAND_MAX;产生 [-a,0] 之间的随机数: rand()*(-a) / RAND_MAX;产生 [a,b] 之间的随机数&#xff1a; a rand()*(b - a) / RAND_MAX;产生随机整数&#xff1a; v1 rand() % 100; // v1 in the range 0 to 99 v2 rand…

作者头像 李华
网站建设 2026/3/28 4:23:39

大模型系统学习:提示词工程指北

提示词工程&#xff08;Prompt Engineering&#xff09;作为大语言模型&#xff08;Large Language Model&#xff0c;LLM&#xff09;应用构建的一种方式被简要提及&#xff0c;本文将着重对该技术进行介绍。 提示词工程就是在和LLM聊天时&#xff0c;用来让模型回答得更好的一…

作者头像 李华
网站建设 2026/3/30 12:26:10

基于图神经网络的大规模图数据异常检测实践

图神经网络在大规模图数据异常检测中的实践&#xff1a;从原理到落地的完整指南 关键词 图神经网络(GNN)、大规模图数据、异常检测、图表示学习、社区发现、流式处理、分布式训练 摘要 在社交网络、金融交易、推荐系统等场景中&#xff0c;图数据已成为刻画复杂关系的核心结…

作者头像 李华
网站建设 2026/4/12 0:05:23

LangFlow Iterator迭代器模式遍历节点

LangFlow 中的迭代器模式&#xff1a;让 AI 工作流“动”起来 在构建智能应用时&#xff0c;我们常常需要处理一类典型任务&#xff1a;对一批数据重复执行相同的逻辑。比如&#xff0c;分析100条用户评论的情感倾向、批量生成产品描述、或多轮调用语言模型完成复杂推理。传统做…

作者头像 李华
网站建设 2026/4/11 4:38:09

贪心算法完全指南

贪心算法是一种在每一步选择中都采取当前状态下最优选择的算法策略&#xff0c;期望通过局部最优解达到全局最优解。&#x1f3af; 贪心算法的核心思想基本概念贪心算法在每个决策点都做出在当前看来最好的选择&#xff0c;不考虑未来后果。这种"短视"的策略在某些情…

作者头像 李华