前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Vue/.Net 开发微信H5页面问题笔记

Vue/.Net 开发微信H5页面问题笔记

作者头像
李郑
发布于 2019-12-11 13:09:06
发布于 2019-12-11 13:09:06
76000
代码可运行
举报
文章被收录于专栏:漫漫全栈路漫漫全栈路
运行总次数:0
代码可运行

帮朋友开发微信H5分享统计系统,也算是自己从头开始写的第一个Vue 项目,遇到不少坑,记录一下。

Vue-Router History模式下 Build 之后访问异常

Vue-Router 的默认模式为 hash 模式,会在链接中加上一个 # ,非常难看,使用 history 模式后,则可以去除。

修改方式为在,/router/index.js中 修改:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const router = new VueRouter({
  mode: 'history',   //指定模式为 history 模式
  base: process.env.BASE_URL,
  routes
})

在本地测试时一切正常,但是build 后发布到服务器,需要为 nginx 添加一条 localtion 记录。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
location / {
    root   /usr/share/nginx/html/h5share;
    index  index.html index.htm;
    try_files $uri $uri/ /index.html;   #添加try_files 后正常
}

微信授权跨域问题

第一次开发,参考网上的教程,直接纯前端获取了微信的 access_token 实际上是不可取的 导致在发布上线后,立即出现了跨域的问题

code和 access_token 都应该由后端获取并缓存。

token要放在服务器就会解决跨域问题,同时补充下为什么要放到服务器生成:

  • 微信对token的生成获取是有次数限制的,每个客户端单独获取,很容易超过限制。每日获取token的限制是2000次。 详细内容:接口频率限制说明
  • access_token(有效期7200秒,开发者必须在自己的服务全局缓存access_token) 某一个客户端新生成一个token后,其他的客户端的token都会失效 官方解释:如果第三方不使用中控服务器,而是选择各个业务逻辑点各自去刷新access_token,那么就可能会产生冲突,导致服务不稳定。

引用自segmentfault

.Net Core 开启 Cors 跨域

直接在 startup.cs 中配置,注意在 MVC之前

在ConfigureServices 中注册 Cors

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
services.AddCors(options =>
   options.AddPolicy("AllowRequest",
   p => p.AllowAnyOrigin()) //允许所有跨域请求
 );

在Configure 中使用 Cors

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
app.UseCors("AllowRequest");

Axios 与 Web API 通讯

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let getAccessUrl = `http://leepush.azurewebsites.net/api/weixin/getAccessToken?code=${code}`

    //loading
    const loading = this.$loading()

    let _that = this
    axios
      .get(getAccessUrl)
      .then(response => {
        console.info(response)
        _that.userinfo = response.data
        loading.close()
        //add user to sys
        let adduserUrl = `http://leepush.azurewebsites.net/api/weixin/AddUserToSys`
        axios
          .post(adduserUrl, {
            "nickname": _that.userinfo.nickname,
            "openid": _that.userinfo.openid,
            "headimgurl": _that.userinfo.headimgurl
          })
          .then(re => {
            console.info(re)
          })
      })
      .catch(error => console.error(error))
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-10-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
微信网页开发
套用《围城》里老学究的的一句开场白:"兄弟我刚入行的时候…“兄弟我是很不喜欢微信这样一款应用的——尽管我在2011年就已经是微信的注册用户。在我看来,第一个,能用qq达到的目的为什么还要微信?其次,凭什么一个开发要绑在一款微信里?但是,周边的人似乎在我毕业的前后通通用上了微信。
一粒小麦
2019/08/13
4.2K0
.NET微信网页开发之网页授权获取用户基本信息
当用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑。我们一般通过用户网页授权来无感实现用户登录,并获取用户的微信信息。
追逐时光者
2023/12/13
4840
.NET微信网页开发之网页授权获取用户基本信息
Dubbo 分布式架构搭建教育 PC 站 - 微信登录
微信开放平台(针对开发者和公司):https://developers.weixin.qq.com/doc/oplatform/Website_App/WeChat_Login/Wechat_Login.html
RendaZhang
2020/11/04
1.2K0
使用vue-cli创建项目登陆页面
打开 src目录下的main.js,该文件是项目的入口文件,所以在这里导入,其他组件均可使用,不用再导入。
用户10196776
2022/11/22
1.3K0
使用vue-cli创建项目登陆页面
微信网页授权之使用完整服务解决方案
依附于第三方的开发,做为开发者经常会遇到第三方进行规范和开发的调整,如开发腾讯微信的相关应用。我所经历的如小程序隐私政策调整、信息备案调整、微信授权获取个人信息限制调整等。
初九之潜龙勿用
2024/06/20
1.1K0
微信网页授权之使用完整服务解决方案
微信公众号开发之授权获取用户信息
测试号:找到 网页授权获取用户基本信息>点击修改>设置域名 服务号:找到 开发>接口权限>网页授权获取用户基本信息>>点击修改>设置域名
Javen
2018/08/21
3.7K1
微信公众号开发之授权获取用户信息
【愚公系列】2022年09月 微信小程序-微信小程序实现网页一键登录功能
如果微信小程序要获取微信登录的用户信息,需要拿到code去后台换取用户信息,具体步骤又如下:
愚公搬代码
2022/10/05
1.7K0
Vue开发微信H5页面总结
刚入门前端的时候写过很多的微信H5页面,时隔多年感觉应该是手到擒来,不曾想竟很是费了一些功夫。现在把本次开发过程中遇到的问题以及我是如何解决的,做个记录。防止自己以后再去解决解决过的问题。
前端黑板报
2018/12/24
4.5K0
Thinkphp5实现微信网页授权登录,保存用户信息到Mysql数据库
去新的公司上班有大半个月了,在公司负责一个项目手机端的官网,其中有一个需求就是要用到微信网页授权登录,今天整理了一下代码逻辑给大家分享出来,希望对大家有所帮助。
程序猿的栖息地
2022/04/29
3.1K0
Thinkphp5实现微信网页授权登录,保存用户信息到Mysql数据库
vue.js应用开发笔记
用户1141560
2017/12/21
2.6K1
vue.js应用开发笔记
Java微信公众平台开发(十)--微信用户信息的获取 (一)关注被动回复图文消息的实现。(二)pc界面显示用户
前面的文章有讲到微信的一系列开发文章,包括token获取、菜单创建等,在这一篇将讲述在微信公众平台开发中如何获取微信用户的信息,在上一篇我们有说道微信用户和微信公众账号之间的联系可以通过Openid关联,所以在这里我们就采用openid去获取用户微信信息。并实现两个个简单场景应用:(一)当微信新用户关注我们的微信公众平台的时候我们自动回复一篇图文消息,然后在图文消息中标题为:【尊敬的:XXX,你好!】,而且在图文消息中的图片就是用户的微信头像,如下图:(二)pc界面显示用户的昵称,性别,头像
用户2417870
2019/09/18
1.2K0
Java微信公众平台开发(十)--微信用户信息的获取

        (一)关注被动回复图文消息的实现。(二)pc界面显示用户
微信OAuth授权获取用户OpenId-JAVA(个人经验)
源码在这里。https://zb.oschina.net/market/opus/1444646_161 维护服务器。一份5元。自愿购买
小帅丶
2018/02/09
7.9K0
微信OAuth授权获取用户OpenId-JAVA(个人经验)
前端-Vue2.0 项目开发实战经验
在不同的路由页面,我们需要动态的修改文档标题,可以将每个页面的标题配置在路由元信息 meta 里面带上,然后在 router.beforeEach 钩子函数中修改:
grain先森
2019/03/28
1K0
前端-Vue2.0 项目开发实战经验
微信小程序实现扫码登录网站
最近使用腾讯云时,用的都是微信扫码登入,发现会跳转到腾讯云助手小程序进行确认登入。感觉挺好用的,就想做一个扫码登入。
王秀龙
2021/09/09
7.5K3
PHP公众号开发给用户发微信消息提醒功能
最近做的一个项目,当有用户有资金到账或者成员变动时需要给他发一条微信消息提示。针对这个,开始想使用模板消息,但是刚注册的公众号申请消息模板需要几天时间申请,在时间不足下选择了使用客服消息接口,微信文档地址: https://mp.weixin.qq.com/wiki。
北桥苏
2024/05/29
3860
企业微信&小程序授权全链路打通指南
近期,我在致力于打造自己的小程序产品时,迎来了一项关键性的进展——微信相关授权流程的完整实现。从用户登录到权限获取,我们细致入微地梳理并实现了每一项授权机制,确保了用户体验的流畅与安全。
程序员海军
2024/12/22
4070
企业微信&小程序授权全链路打通指南
.Net微信开发之通过UnionID机制,解决用户在不同公众号,或在公众号、移动应用之间帐号统一问题
  最近一段时间一直在做关于微信方面的网站应用开发,这段时间也收获的不少关于微信开发方面的开发技能,接触的比较多的主要有微信公众号和微信网站app第三方登录授权,以及微信会员卡,优惠券和扫描二位码的功能,今天我主要想要总结的是微信公众号登录和网站app第三方应用微信授权登录这两者之间获取到的Openid关联问题,实现两边登录都是同一个账号。
追逐时光者
2019/08/28
1.2K0
.Net微信开发之通过UnionID机制,解决用户在不同公众号,或在公众号、移动应用之间帐号统一问题
Vue实战开发
4.新建Fwsb组件,这个相当于程序员的入口文件。在src/components/目录下新建Fwsb.vue文件。文件内容
楠楠
2018/09/11
7770
微信公众号发布提醒(微信公众号模板消息接口)
灵感来源于学校的 每日健康日报,要求使用微信小程序进行每日健康打卡。所以此项目的功能类似于 QQ群机器人,或者是 每日闹钟。
全栈程序员站长
2022/07/26
13.2K0
微信公众号发布提醒(微信公众号模板消息接口)
微信网页授权
用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑。
超超不会飞
2020/09/18
2.8K0
微信网页授权
推荐阅读
相关推荐
微信网页开发
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验