侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Vue+abp微信扫码登录的实现代码示例

前端  /  管理员 发布于 3年前   259

最近系统中要使用微信扫码登录,根据微信官方文档和网络搜索相关文献实现了。分享给需要的人,也作为自己的一个笔记。后端系统是基于ABP的,所以部分代码直接使用了abp的接口,直接拷贝代码编译不通过。

注册微信开放平台账号#

在微信开放平台注册,注意是开放平台不是公众平台,这里需要300元,然后申请网站应用。审核通过后获取到AppID和AppSecret以及登记的网站url。只有此url下的地址微信扫码后才能回调。

具体申请条件见官方文档。

生成登录二维码#

在vue登录页面嵌入登录二维码,根据官方文档,在页面中放入一个div元素,二维码就放在此元素中,注意var obj = new WxLogin必须放在mounted方法中执行,此时vue才会把dom元素初始化挂载到dom树,可以参见vue官方文档生命周期介绍。

注册回调事件#

用户扫码后微信会回调访问前一步提供的redirect_uri,这里要监控微信回调,并用微信返回的code请求后端,在后端再去访问微信服务器获取token及用户openID

在回调页面中监控路由改变事件以监控微信回调(因为我的二维码和回调在同一个路由页面),如果有其他更好的方法请告诉我。

 @Watch("$route") async RouteChange(newVal, oldVal) {  await this.weixinRedirect(); } // 请求微信后台 async weixinRedirect() {  let code = this.$route.query.code;  let state = this.$route.query.state;  if (code) {   let wxTo = {    code,    state   };   //请求后台   this.$http("*/WeixinRedirect",data:wxTo).then((token)=>{     //登录成功,把token写入cookie     //跳转到主页      this.$router.replace({ path: "/", replace: true });   }).catch(error => {     //保持当前页面     this.$router.replace({ path: "/login", replace: true });    });  } }}

后端接收code请求token#

在appsettings.json中配置AppId和AppSecret

[HttpPost]public async Task WeixinRedirect(string code, string state){  if (code.IsNullOrEmpty())  {    throw new UserFriendlyException("微信授权失败,请重新授权");  }  var appid = configuration["Authentication:Wechat:AppId"];  var secret = configuration["Authentication:Wechat:AppSecret"];  var url = $"https://api.weixin.qq.com/sns/oauth2/access_token?appid={appid}&secret={secret}&code=[code]&grant_type=authorization_code";  var httpClient = httpClientFactory.CreateClient();  httpClient.DefaultRequestHeaders.Add("User-Agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)");  httpClient.Timeout = TimeSpan.FromMinutes(3);  var resstr = await httpClient.GetStringAsync(url);  try{    //如果微信授权返回失败这里序列化不成功   var res = JsonSerializationHelper.DeserializeWithType(resstr);  }catch (Exception e)  {    throw new UserFriendlyException("获取微信access_token失败");  }  if (res == null || res.openid.IsNullOrEmpty())  {    throw new UserFriendlyException("获取微信access_token失败");  }  var userId = //根据openID获取用户id,我们系统要求用户提前把微信和用户关联绑定,所以这里可以根据微信用户的openID获取到户农户id;  //使用用户直接登录  if (!userId.IsNullOrEmpty()&&long.TryParse(userId, out long id))  {    var user = await _userManager.GetUserByIdAsync(id);    var loginResult = await _logInManager.LoginByUser(user);    string accessToken = CreateAccessToken(CreateJwtClaims(loginResult.Identity));    return new AuthenticateResultModel    {      AccessToken = accessToken,      EncryptedAccessToken = GetEncrpyedAccessToken(accessToken),      ExpireInSeconds = (int)_tokenConfiguration.Expiration.TotalSeconds,      UserId = loginResult.User.Id    };  }  throw new UserFriendlyException("微信尚未绑定账号,请使用账号登录后绑定微信。");}

WeiXinAccess_tokenResponse类型

public class WeiXinAccess_tokenResponse{  public string access_token { get; set; }  public int expires_in { get; set; }  public string refresh_token { get; set; }  public string openid { get; set; }  public string scope { get; set; }  public string unionid { get; set; }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

您可能感兴趣的文章:

  • vue 微信扫码登录(自定义样式)
  • vue实现扫码功能


  • 上一条:
    Vue学习之组件用法实例详解
    下一条:
    检查电脑是否被安装木马的三个小命令
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在js中使用URL类用来解析处理URL的示例代码(0个评论)
    • js中动画事件:requestAnimationFrame、transitionend、animation...(0个评论)
    • 在js中mouseover和 mouseenter的区别浅析(0个评论)
    • uniapp调用手机实现打电话录音功能示例代码(0个评论)
    • 在uniapp开发微信小程序中图片大小显示不正常解决方法(0个评论)
    • 近期文章
    • 在laravel框架中的5个HTTP客户端技巧分享(0个评论)
    • 在go语言中使用FFmpeg库实现PCM音频文件编码为mp3格式文件流程步骤(0个评论)
    • gopacket免安装Pcap实现驱动层流量抓包流程步骤(0个评论)
    • 在laravel项目中实现密码强度验证功能推荐扩展包:password-strength(0个评论)
    • 在go语言中用filepath.Match()函数以通配符模式匹配字符串示例(0个评论)
    • Laravel Response Classes 响应类使用优化浅析(0个评论)
    • mysql中sql_mode的各模式浅析(0个评论)
    • 百度文心一言今天发布,个人第一批内测体验记录,不好别打我(0个评论)
    • 嘿加密世界让我们谈谈在共识中将中本聪主流化(0个评论)
    • 在go语言中寻找两个切片或数组中的相同元素/共同点/交集并集示例代码(0个评论)
    • 近期评论
    • 博主 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 @ xiaoB 你只管努力,剩下的叫给天意;天若有情天亦老,..
    • xiaoB 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 会不会春节放假后又阳一次?..
    • BUG4 在

      你翻墙过吗?国内使用vpn翻墙可能会被网警抓,你需了解的事中评论 不是吧?..
    • 博主 在

      go语言+beego框架中获取get,post请求的所有参数中评论 @ t1  直接在router.go文件中配就ok..
    • Jade 在

      如何在MySQL查询中获得当月记录中评论 Dear zongscan.com team, We can skyroc..
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客