标签:扫描 arp 情况 symbol opera web app 验证配置 需要 state
需求场景
这个微信网页是一个用户测试的活动。开始测试之前需授权获取用户信息,所以新建一个firstPage页面作为/页面来判断需不需要授权。如果测试完成分享给用户,用户看到的是分享人的结果页面,这个页面是不需要授权的。扫描其中的二维码开始测试才需要授权。所以在前端路由里传一个query 的参数。根据这个参数(this.$route.query.xxx)判断,用户打开的是结果页(不需授权)还是测试页(需授权)。
流程
import wx from ‘wx-sdk-ts‘
import wx from‘weixin-js-sdk‘
通过config接口注入权限验证配置
所有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用(同一个url仅需调用一次,对于变化url的SPA的web app可在每次url变化时进行调用)
记录开发过程中几个坑
let url = encodeURIComponent(
" http://xxx.cn/h5/migrationQuiz/auth?router_path=home&fromwxuser="
);
url = url + userId;
window.location.href =
"https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx6e8235ac81ee7570&redirect_uri=" +
url +
"&response_type=code&scope=snsapi_userinfo&state=STATE&connect_redirect=1#wechat_redirect";
这里注意:因为前端路由是带#的。比如重定向后跳转的页面是:http://xxx.cn?id=xxx#/home 这个时候如果直接给后端这个地址,发现这个页面是找不到的。在这个项目中后端在路由里传入了一个router_path的参数。我要重定向到#/home页面,就在地址中加上router_path=home即可。另外附上后端nodejs代码。看到这个,大家应该不难懂了。
let debug_redirect_url = encodeURIComponent("www.example.com");
let url = encodeURIComponent(
" http://xxx.cn/h5/migrationQuiz/auth?debug_redirect_url=" +
debug_redirect_url +
"&router_path=home&fromwxuser="
);
如上,本地开发配置的域名为:www.example.com
这里注意:为了能够正常使用开发者工具调试,配置的域名应在公众号JS接口安全域名下。
build -> config -> index.js -> build{} -> assetsPublicPath: ‘./‘
由于本项目中用到了vuecli3+typescript: 所以相应的配置如下:
由于本项目最后生成的结果页是一个html页面。而产品的需求是,在最终的结果页面,可以长按保存成图片,也就是要在前端将h5页面生成一张图片。用到了html2canvas。具体使用方式参见代码。在处理这个功能的时候,也遇到了一个大坑。参照如图所示:
就是因为最终要生成的图片有用户的微信头像,跨域了,不得不说,微信还是很坑的。最终后端给的解决方案是:
将用户的微信头像改成通过我们这边h5的服务器来获取,然后再发给前端头像地址,改成用我们的服务器的地址。
至此,这个项目就算完工了。
最后
由于本项目使用微信开发者工具进行本地测试,需配置本地域名(www.example.com),且配置的域名应在公众号JS接口安全域名下。测试过程中使用到了nginx,所以附上nginx的配置代码。
127.0.0.1 localhost
127.0.0.1 www.example.com
start nginx
nginx -s reload
server {
listen 80;
server_name www.example.com;
// 跨域配置
location ^~ /h5/ {
proxy_pass http://xxx.cn;
}
// 代理到本地
location / {
proxy_pass http://localhost:52152;
}
# location / {
# root html;
# index index.html index.htm;
# }
}
其他情况请参考几篇不错的文章:
https://juejin.im/post/5aef2db3f265da0b9c10899e
https://www.jianshu.com/p/1a35e1dbe1ad
另附本项目github地址:https://github.com/clara222/wxh5
记一次使用vue+typescript做微信公众号网页分享的坑
标签:扫描 arp 情况 symbol opera web app 验证配置 需要 state
原文地址:https://www.cnblogs.com/ygunoil/p/12931239.html