百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

微信开发-网页授权域名设置如何超过2个

yuyutoo 2025-02-15 18:05 1 浏览 0 评论

大家好,我是yangyang.今天分享一个微信开发问题-“网页授权域名受限,如何办”,想必,也有很多小伙伴早已遇到并解决了.小编在这里就整理了网络大佬的解决方案分享给大家.

方案一:中转代理服务-代码实现

思路流程

  • 准备一个中间域名,假设叫:oauth.888.com
  • 微信公众号网页授权上填这个代理域名 oauth.888.com
  • 所有 需要微信网页授权的客户端页面都向 oauth.888.com 请求
  • 然后由 aoauth.888.com 统一向 微信服务器进行发起网页授权请求
https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx520c15f417810387&redirect_uri=https://chong.qq.com/php/index.php?d=&c=wxAdapter&m=mobileDeal&showwxpaytitle=1&vb2ctag=4_2030_5_1194_60&response_type=code&scope=snsapi_base&state=123#wechat_redirect

用户同意授权后

如果用户同意授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE。

code说明:

code作为换取access_token的票据,每次用户授权带上的code将不一样,code只能使用一次,5分钟未被使用自动过期。

  • 微信服务器带着code 重定向 oauth.888.com
  • oauth.888.com 将code 拼接真实客户端需要授权页面的地址 为 url
- 假设真实客户端是:shop.888.com
- 真实客户端进行网页授权:请求到oauth.888.com,假设是:https://oauth.888.com?redirect=https://shop.888.com
- oauth.888.com 将code 拼接真实客户端需要授权页面的地址 为 url:https://shop.888.com?code=CODE&state=STATE
  • oauth.888.com 重定向 url 到客户端
  • 客户端可以通过 url 拿到 微信授权过的 code

流程图

伪代码

真实客户端shop.888.com 根路径(用php举例),入口文件index.php 写入如下代码,当用户访问就会走入上面的流程

header("location:https://ouath.888.com/code.php?redic=redirect=https://shop.888.com");

参考文章
:https://blog.csdn.net/u013887008/article/details/119979824

方案二:中转代理服务-nginx实现

思路流程

  • 准备一个中间域名,假设叫:oauth.888.com
  • 然后在这个通用域名的机器上,配置nginx 代理转发(proxy_pass),转发到专门的项目就可以 :
  • 比如A项目的实际域名是shop.888.com。使用这种方案以后,在微信公众号里面的访问路径则是oauth.888.com/shop
  • 比如B项目的实际域名是erp.888.com。使用这种方案以后,在微信公众号里面的访问路径则是oauth.888.com/erp

这样的做的原因有以下几点
① 多条业务线,可以不用塞在一个目录下面。大家独立管理部署自己的业务线项目代码就可以。
oauth.888.com则统一负责微信配置文件的验证和nginx转发

  # oauth.888.com机器的nginx配置文件

  location /MP_verify_666.txt {
    add_header  Content-Type  "text/plain";
    alias /www/wwwroot/shop.888.com/public/MP_verify_666.txt;
  }

  location /shop/  {
    proxy_pass https://shop.888.com/;
  }


  location /erp/  {
    proxy_pass https://shop.888.com/;
  }

② 域名友好型,各项目业务线可以在oauth.888.com下面设置符合自己业务需求的目录名。比如iot业务可以设置为oauth.888.com/iot/

③ 具备可扩展性,后期再在当前公众号增加其他业务线的项目,只需要在oauth.888.com 的nginx配置文件 增加一条proxy_pass配置即可

参考文章
:https://blog.csdn.net/weixin_44050791/article/details/132095710

总结

以上两种方案,无论是通过中转代理服务的代码实现还是通过Nginx实现,都可以有效地解决微信开发中遇到的网页授权域名受限的问题。这两种解决方案不仅可以帮助开发者避免因域名受限而导致的授权失败,还提供了灵活性和扩展性,使得多个业务线可以独立管理部署自己的项目代码,同时在需要增加其他业务线的项目时,也可以轻松地进行扩展

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: