1 Star 0 Fork 23

小雨在线 / WechatOauthProxy

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
MIT

微信授权登录代理转发

功能描述

请求源用get方式请求代理微信授权登录地址,代理服务器获取参数后向微信服务器发起请求,从而获取code或获取access_token及openid,最后代理服务器将转发回请求源。避免了微信公众号授权登录接口只能同时由同一域名发起的限制。

安装使用

  1. 本项目仅支持php环境,其他后端语言不支持。将本项目部署到服务器上(demo目录内为应用请求端向代理端发起请求的例子,可删除)。

  2. 需要使用一个新域名(如:oauth.xx.com)解析到服务器公网ip上,此域名将作为微信授权登录的回调域名,修改web服务器配置:将新域名应用目录指定到该项目根目录,并重启web服务器。

  3. 访问 http://oauth.xx.com/verify.html 进入页面后,在输入框填写授权登录回调域名的验证文件(txt格式)的内容,然后点击“提交”按钮。成功提交后,点击页面中的“复制微信授权回调域名”按钮复制回调域名(oauth.xx.com)。

  4. 复制成功后,进入微信平台,在微信授权回调域名处填写复制的回调域名(oauth.xx.com)即可。

  5. 此时代理地址(get):http://oauth.xx.com/index.php
    请求参数:

    参数 解释 是否必须 备注
    app_id 公众号id
    scope 微信登录授权作用域 可选值:"snsapi_base"或"snsapi_userinfo"
    redirect_uri 授权回调地址 一般为发起授权登录的请求地址,需要用urlencode处理
    proxy_scope 代理操作作用域,用于判断获取code还是access_token 可选值:"code"或"access_token",默认"code"
    app_secret 公众号密钥 若proxy_scope为access_token,则此参数也需要
    oauth_type 授权类型,1:公众平台,2:开放平台 可选值:1或2,默认1
    state 重定向参数
  6. 根据请求地址及参数访问(使用header()函数)即可。若proxy_scope参数为"code",则返回的地址将会带有code和state参数。若proxy_scope参数为"access_token",则返回的地址将会带有access_token和openid参数。

举例说明

  • 获取code
  1. 代理项目地址为 "http://oauth.xx.com/index.php"。
  2. 首先必须将公众号授权回调域名设置为 "oauth.xx.com"。
  3. 在 "http://request.xx.com/index.php" 页面内请求代理地址: "http://oauth.xx.com/index.php?app_id=APPID&scope=SCOPE&redirect_uri=REDIRECT_URI"。
  4. 正常情况下最终将跳转到 "http://request.xx.com/index.php?code=CODE&state=STATE"。
  5. 获取到code后,再通过微信授权登录接口获取access_token、获取用户信息即可。
  • 获取access_token
  1. 代理项目地址为 "http://oauth.xx.com/index.php"。
  2. 首先必须将公众号授权回调域名设置为 "oauth.xx.com"
  3. 在 "http://request.xx.com/index.php" 页面内请求代理地址: "http://oauth.xx.com/index.php?app_id=APPID&scope=SCOPE&proxy_scope=access_token&app_secret=APPSECRET&redirect_uri=REDIRECT_URI"。
  4. 正常情况下最终将跳转到 "http://request.xx.com/index.php?access_token=ACCESS_TOKEN&openid=OPENID"。
  5. 后续根据微信授权登录接口用access_token及openid获取用户信息即可。

其它说明

  • 本项目中的access_token与微信基础接口调用凭据的access_token无关,仅用于微信授权登录使用。
  • 若仅获取code,请注意将access_token返回数据做缓存处理。
  • 若获取access_token,则无需再对access_token返回数据单独缓存。若部署在Linux服务器,由于需要创建目录及文件,所以项目需要修改权限。另外,php环境需要开启session、cookie。还有,由于获取access_token需要传递app_secret参数,为减小app_secret泄露的风险,代理地址建议启用https。

体验地址

使用的是微信公众测试号的授权登录接口,仅供测试学习。进入后请先识别二维码关注测试号。
代理端url:http://wxoauth.hillpy.com/index.php
请求端url:http://test.hillpy.com/wxoauth/index.php
MIT License Copyright (c) 2018 shinn lancelot Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

简介

微信公众号授权登录代理转发 展开 收起
PHP
MIT
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
PHP
1
https://gitee.com/xiaoyuedu/WechatOauthProxy.git
git@gitee.com:xiaoyuedu/WechatOauthProxy.git
xiaoyuedu
WechatOauthProxy
WechatOauthProxy
master

搜索帮助