一个公众号多个网页授权

一个公众号多个网页授权

问题描述

  • 你是否遇到过这各情况,在H5开发时,要用到微信授权,可同一个服务号只能填写两个域名,这样每开发一个应用就要换域名。
  • 用vue开发时,因用到微信授权,每次都要打包上传到服务器上,才可以调试

解决问题思路

  • 遇到这样的问题太棘手了。有没有这样一种方法,在微信服务器各我前端请求中间再加上一个中转服务器,我要微信制授权,就都去找中转服务器,再由中转服务器统一去微信要授权,得到授权后,转发到请求前端
  • 之前的流程
前端 微信 我要授权 给你授权 前端 微信
  • 加上中转服务器
前端 中转服务器 微信 我要授权 有人要授权 给你授权 给你授权 前端 中转服务器 微信
  • 按照上边的思路
  1. 首先我要搭建中转服务器
  2. 在中转服务器上处理前端和微信发来的数据请求

解决方法

oauth.php

<?php
//微信授权带code回调
$url = $_GET['redirect_uri'];
unset($_GET['redirect_uri']);
if( strpos($url,'?') === false ){
    $url .= '?' . http_build_query($_GET);
}else{
    $url .= '&' . http_build_query($_GET);
}
//跳转
//header("Location:".$url);
//var_dump($url);
echo "
    <script>
        location.href='{$url}';
    </script>
";

  • 在你的服务器上配置一个站点,内容就放oauth.php这个文件
    比如我的站点是oauth.abcde.cn
  • 在微信授权接口那填写的地址是:http://oauth.abcde.cn/oauth.php
    同时要把微信验证文件放到站点中
  • 要授权页面代码(js)
function get_oauth(){
	var AppID = 'your AppID ';

	var redirect_uri = location.origin + location.pathname + location.hash

	//加上中间件的回调
	redirect_uri = "http://oauth.abcde.cn/oauth.php?redirect_uri=" + redirect_uri;
	
	//编码
	redirect_uri = encodeURIComponent(redirect_uri);
	
	location.href="https://open.weixin.qq.com/connect/oauth2/authorize?appid="+AppID+"&redirect_uri="+redirect_uri+"&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect";
}

以上就是一个公众号多个网页授权方法

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值