【h5+微信小程序】vue2实现h5扫码登录功能

前言

需要实现在同域名的h5页面上增加一个微信扫码登录的功能,如果用户已经有小程序的账号,可以直接登录。

使用:vue2+微信小程序原生开发
可以实现上述功能的前提是:同一用户,对同一个微信开放平台下的不同应用,UnionID是相同的。域名已经配置。
可以用什么来区分是否为同一用户呢?目前项目里还是用的手机号。

正文

流程

页面嵌入二维码->用户扫码后获得临时code->发送code到后台,后台返回用户的信息

  1. 在index.html页中引入地址(但是报错了,我的解决方案在下面)
<script src="https://res.wx.qq.com/connect/zh_CN/htmledition/js/wxLogin.js"></script>
  1. 在展示二维码的页面增加如下代码,进行实例化
  //login.vue
  //二维码容器
  <div id="login_container"></div>

//在mounted中执行下面的代码,获取二维码
    //获得登录二维码
    getwxCode() {
      var obj = new WxLogin({
        id: "login_container",
        appid: "自己的",
        scope: "snsapi_login",
        redirect_uri: encodeURI("自己的"),
        state: "",
        style: "black",
        href: "自定义的样式..../qrcode.css",
        self_redirect: false,
      });
    },

这时候如果能正确展示二维码,使用手机扫码的话,就会跳转到redirect_uri,后面拼接上传回来的code值。
3.正常来讲应该在一个把redirect_uri设置为一个中间页,在中间页上进行code的处理的。
但是因为用的是history模式,所以就在首页先实现了。

  mounted() {
    this.getCodeMes();
  },
    getCodeMes() {
      let code = this.getQueryString("code");
      console.log("code:", code);
      if (!code) {
      return
      } else {
        this.getLoginMes(code);
      }
    },
    //使用正则读取url里的code
    getQueryString(name) {
      var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
      // console.log(window.location.search);
      var r = window.location.search.substr(1).match(reg);
      if (r != null) {
        return unescape(r[2]);
      }
      return "";
    },
    //对接后端接口,获取用户信息
    getLoginMes(code) {
      let params = {
        code: code,
      };
      let queryParams = new URLSearchParams(params);
      fetch("后端接口", {
        method: "POST",
        body: queryParams,
      })
        .then((response) => {
          if (response.ok) {
            return response.json();
          }
          console.log(response);
          throw new Error("Network response was not ok.");
        })
        .then((data) => {
          console.log(data);
          //如果code过期失效了处理
          if (data.code == "100") {
            //清除一下地址上的code
            window.history.replaceState(
              null,
              null,
              window.location.href.split("?")[0] + window.location.hash
            );
            this.$router.push("/");
          }
          if (data.code == "200") {
            localStorage.setItem(
              "userinfo",
              JSON.stringify(data.result)
            );
            
            setTimeout(() => {
              window.history.replaceState(
                null,
                null,
                window.location.href.split("?")[0] + window.location.hash
              );
              this.$router.push("/登入后的页面");
            }, 2000);
          } 
        })
        .catch((error) => {
          console.error("There was a problem with the network request:", error);
        });
    },
  },

这样就基本完成了

遇到的问题

  1. 步骤1中引入地址后,谷歌浏览器上报错如下:
Unsafe JavaScript attempt to initiate navigation for frame with URL 'http://www.xxx.xxx/' from    frame with URL "https://open.weixin.com/xxxxxxx" The frame attempting navigation is targeting its top-level window, but is neither same-origin with its target nor is it processing a user gesture

解决方法:引入的js文件换成下面的
原因:浏览器禁止重定向
解决方法:直接参考里面的代码即可
https://www.cnblogs.com/enhengenhengNymph/p/14450416.html
2. 二维码无法正常显示,报错:Oops! something went wrong
- 我的原因是:“授权回调域”写错了。没有和开放平台的对上。
- 其他可能的原因:先排除不是网站备案问题,不是第三方与微信平台配置的问题,也不是公众号里面没有设置业务域名或js接口安全域名。
- 参考

参考和补充

参考

0.微信官方:网站应用微信登录开发指南
1.vue 微信扫码登录嵌入方式及开发踩的坑点:比较详细,从获取appid到二维码样式都有说到。不足是没有继续说明扫码的过程了。
2.vue 实现PC端微信扫码登录(二维码内嵌网页版):有比较完整的流程,使用路由拦截code,还包括了如果扫码用户未注册的绑定?(我没试过)
3.前端实现 微信扫码登录网站 pc端(二维码嵌套页面) 超详细,包会:是挺详细的,关于样式自定义也有说,但是图挂了。
4.关于二维码的生成和嵌入讲得比较详细:关于二维码的生成和嵌入讲得比较详细
5.如何实现微信扫码登录功能(Vue):很全,包括后端使用Node.js的部分也有写到。从注册到获取token。100分!
6.微信小程序如何获取用户unionId?前置知识可看下

补充

其他参考&方案

Vue微信登录流程:使用的是vue-wxlogin,感觉差不多,只是不需要引入script

其他优化

  1. 完成登录之后,处理一下code,去掉它。(只是为了让url看起来清爽点)

其他待优化

1.没有用history模式,所以扫码完,只能先返回...8080/这个页面接收code。(不能带#号,#后面的会被清除掉
2.可以参考这种样式,使用图标进行登录方式的切换,这样UI还挺好苦的。vue - 网站接入微信扫码登录功能详细教程,完整详细流程及完整功能示例源代码(附常见问题的解决方案与二维码样式修改方案)一个付费专栏的文章,没有看。
3.可以接着增加二维码的有效期、自动/手动刷新等功能。

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Vue、Spring Boot、微信H5支付、电商、Git 是一些常见的技术和工具。下面我将依次对它们进行解释和描述: Vue 是一个现代化的前端框架,采用了一种响应式的编程方式,可以轻松构建交互丰富、高性能、可维护的web应用程序。Vue 提供了诸多的功能和特性,例如组件化开发、虚拟DOM、数据双向绑定等,极大地提高了前端开发的效率。 Spring Boot 是一个轻量级、快速开发的Java后端框架,它简化了Spring应用程序的配置和部署,提供了自动化配置和快速启动的特性。Spring Boot具有强大的生态系统和丰富的功能,可以方便地构建高效、安全且可扩展的后端应用程序。 微信H5支付是微信公众平台提供的一种在线支付方式,可以通过微信支付接口实现在手机浏览器中进行支付。它支持用户在H5页面中通过微信进行支付,适用于电商、在线购物等需要在线支付的场景。微信H5支付具有便捷、安全的特点,可以提供良好的用户支付体验。 电商是指以电子商务技术为支撑,通过互联网进行商品、服务的交易和商务活动的行业。电商平台的建设包括商品展示、购物车、订单管理、支付处理等模块,需求复杂多样。Vue和Spring Boot可以结合使用,前端通过Vue实现电商平台的用户界面,后端采用Spring Boot来开发后台接口和处理业务逻辑。 Git 是一个分布式版本控制系统,用于保存和管理软件开发过程中的各个版本。团队可以通过Git来协同开发,追踪代码变更、回滚、合并等。在开发电商平台时,Git助力多人合作开发,有效地管理代码库,解决并发开发、版本控制的问题。团队成员可以通过Git来共享和提交自己的代码,并通过分支管理功能来进行并行开发和版本控制。 总结来说,Vue是一个前端框架,Spring Boot是一个后端框架,微信H5支付是一种在线支付方式,电商是基于电子商务技术的行业,Git是一个用于版本控制的工具。这些技术和工具可以相互结合,用于开发电商平台,并实现高效、可靠的软件开发和交付。 ### 回答2: Vue是一种流行的前端框架,它使用JavaScript和HTML来构建交互式的用户界面。它具有简单易学、灵活性强以及性能优化等优势,因此在前端开发中得到了广泛的应用。 Spring Boot是一个用于简化基于Java的应用程序开发的框架。它提供了开箱即用的功能,使开发人员能够快速构建高效、可扩展的应用程序。Spring Boot还具有自动化配置和简化部署等特性,使开发过程更加便捷。 微信H5支付是一种在线支付方式,允许用户在手机端使用微信进行购物支付。它具有支付安全、使用便捷以及适用范围广泛的特点,已经成为电商领域中非常常见的支付方式。 Git是一个分布式版本控制系统,它用于跟踪文件的修改和历史记录。在开发过程中,开发人员可以使用Git来管理代码版本,通过分支、合并等功能来协同开发和解决冲突。 综上所述,Vue和Spring Boot是用于构建应用程序的框架,微信H5支付是一种在线支付方式,而Git是用于版本控制的工具。它们在电商领域中都扮演着重要角色,能够使开发人员更加高效地开发、部署和维护应用程序。 ### 回答3: Vue是一个用于构建用户界面的开源JavaScript框架,它采用了MVVM的架构模式,能够使开发者更高效地构建Web应用程序。Vue具有简单易学、灵活可扩展以及高性能等特点,因此在前端开发中广受欢迎。 Spring Boot是一个基于Spring框架的快速开发框架,它通过内嵌的Web服务器、自动化配置和约定优于配置的原则,极大地简化了Java Web应用的开发工作。Spring Boot提供了丰富的开发工具和组件,使得开发人员可以更轻松地构建出高效、健壮的后端应用。 微信H5支付是指在移动端浏览器中使用微信支付功能的一种支付方式,用户可以通过浏览器直接打开商户的H5页面进行支付。微信H5支付不需要下载或安装微信客户端,能够为电商平台提供更便捷的支付方式,提升用户体验并增加交易转化率。 Git是一个分布式版本控制系统,它可以记录和管理代码的版本变更。在团队协作开发中,Git可以帮助开发人员更好地进行代码管理、合并和回滚等操作,确保团队开发的代码始终处于一个稳定的状态。Git也是目前最流行的版本控制工具之一,被广泛应用于软件开发行业。 综上所述,Vue、Spring Boot、微信H5支付和Git分别代表了前端开发、后端开发、支付方式和版本控制等不同方面的技术和工具。结合这些技术和工具,我们可以构建出一个使用Vue作为前端框架,Spring Boot作为后端框架,集成微信H5支付的电商平台,并且通过Git进行代码版本管理和团队协作开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值