这篇文章主要讲解了“小程序如何根据referer跳转不同的后台环境”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“小程序如何根据referer跳转不同的后台环境”吧!
一、问题:
开发小程序的时候有4个版本(开发、体验、审核、正式)。所以不同的环境要请求不同的后台。特别是审核
版本,因为还要微信审核,如果请求错误,会被审核失败。因为生产环境是对应旧的后台版本,所以审核
版本既不能调到后台生产环境,也不能跳到开发环境。
我们为了方便生产
、审核
2个版本小程序都去请求/prod
。这里就要区别真实的请求到底是从生产
、审核
哪里来的。
二、解决思路。
微信给我们服务器发送请求wx.request
的会带上一个referer
的header参数。格式如下:
https://servicewechat.com/<appId>/<version>/page-frame.html
其中<appId>
是发送请求的小程序appId,<version>
是小程序的版本。
开发版:
https://servicewechat.com/小程序appId/0/page-frame.html
体验版:
https://servicewechat.com/小程序appId/0/page-frame.html
devtools:
https://servicewechat.com/小程序appId/devtools/page-frame.html
正式版:
https://servicewechat.com/小程序appId/6/page-frame.html
三、解决方式。通过nginx做服务器选择。
1、定义一个变量 foo
, 配置一个map,把http_referer
映射到foo
。
map $http_referer $foo {
default "prod";
~^https://servicewechat.com/[^/]+/0/(.*)$ "dev";
~^https://servicewechat.com/[^/]+/devtools/(.*)$ "dev";
}
2、配置服务器。
upstream dev {
server localhost:7777;
}
upstream prod {
server localhost:9999;
}
3、location
中使用 foo
变量, 导航到正确的地址。
这里我用add_header
把foo
变量输出一下,作为测试。
location / {
#set $foo "$http_referer";
add_header wkfoo 'foo: $foo "$http_referer"';
proxy_pass http://$foo;
}
4、测试一下。
curl -H 'Cache-Control: no-cache' -I "https://xxx.xxx.com/prod/xxx?参数1=xxx&参数2=xxx" --referer "https://servicewechat.com/xxx/devtools/page-frame.html"
curl -H 'Cache-Control: no-cache' -I "https://xxx.xxx.com/prod/xxx?参数1=xxx&参数2=xxx" --referer "https://servicewechat.com/xxx/0/page-frame.html"
感谢各位的阅读,以上就是“小程序如何根据referer跳转不同的后台环境”的内容了,经过本文的学习后,相信大家对小程序如何根据referer跳转不同的后台环境这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是天达云,小编将为大家推送更多相关知识点的文章,欢迎关注!