微信小程序用户登陆和获取用户信息功能实现

简介: 微信小程序用户登陆和获取用户信息功能实现

官方文档:

https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html

接口说明:

https://developers.weixin.qq.com/miniprogram/dev/OpenApiDoc/user-login/code2Session.html


我们看官方这个图,梳理一下用户登陆的大概流程就是:


1.小程序获取code,将code发给服务器,


2.服务器将appid + appsecret + code发给微信接口


3.微信接口返回 session_key + openid给服务器


4.服务器定义登陆状态,返回token给小程序


5.小程序接收token并保存


1、做一个用户登陆按钮和获取用户信息按钮



<view>
  <button bindtap="getUserInfo" type="primary">获取用户信息</button>
  <button bindtap="wxLogin" type="warn" >登陆</button>
</view>

2、调用微信官方的用户登陆方法和获取用户信息方法


  //获取微信用户的头像和昵称
  getUserInfo() {
    wx.getUserProfile({
      desc: '用于完善会员资料', 
      success: res => {
        console.log('用户信息:', res.userInfo)
      },
      fail: err => {
        console.error('获取用户信息失败', err)
      }
    })
  },
  // 微信登陆
  wxLogin() {
    wx.login({
      success: (res) => {
        console.log(res.code)
      },
    })
  }


3、测试


这里我们可以看到当我点击“获取用户信息”按钮之后,成功返回的用户信息。这说明测试成功了,这里还得提一下,现在新版本的都不会显示用户昵称和头像了,之前旧版本的会直接返回用户真实的头像和昵称,所以不必纠结这一点,这不是问题。

当点击登陆按钮时,返回了code,这也说明咱们的代码是没问题的。


4、小程序发送code给服务器


  // 发送请求
  sendRequest() {
    wx.request({
      url: 'http://localhost:8080/api/user/wxLogin',
      method:'POST',
      data: {
        jsCode: this.code // 将code作为jsCode字段放在data对象中
      },
      success: (res)=>{
        this.token = res.data.data;
        console.log('接收到的token为:' + this.token)
      }
    })
  }
<view>
  <button bindtap="getUserInfo" type="primary">获取用户信息</button>
  <button bindtap="wxLogin" type="warn" >登陆</button>
  <button bindtap="sendRequest" type="default" >发送请求</button>
</view>


5、服务器端代码


@Override
public Result<String> wxLogin(WxLoginParam param) {
    System.out.println("打印code" + param.getJsCode());
    // 得到微信登录信息
    String response = payService.getWxLogin(param.getJsCode());
    if (StrUtil.isEmpty(response)) {
        return Result.fail(ResultCodeEnum.WX_ERROR);
    }
    // 微信会返回一段json,从中得到openid、session_key和unionid
    JSONObject resJson = JSONUtil.parseObj(response);
    String openid = resJson.getStr("openid");
    if (StrUtil.isEmpty(openid)) {
        Result<String> result = new Result<>();
        result.setCode(ResultCodeEnum.SERVICE_ERROR.getCode());
        result.setMessage("调用微信接口异常:" + resJson.get("errmsg"));
        return result;
    }
    // 根据微信用户信息查询
    LambdaQueryWrapper<User> usWrapper = Wrappers.lambdaQuery();
    usWrapper.eq(User::getOpenId, openid);
    synchronized (this) {
        User user = baseMapper.selectOne(usWrapper);
        if (Objects.isNull(user)) {
            // 如果是第一次登录则创建信息
            user = new User();
            user.setOpenId(openid);
            user.setInvokeFlag(ProjectConstant.INVOKE_FLAG_TRUE);
            baseMapper.insert(user);
        } else if (ProjectConstant.INVOKE_FLAG_FALSE.equals(user.getInvokeFlag())) {
            return Result.fail(ResultCodeEnum.ACCOUNT_STOP);
        }
        return Result.ok(JwtUtil.getToken(user.getId(), null));
    }
}


6、测试结果


可以看到我们已经成功地接收到了token,说明成功了。

亲爱的读者,感谢您关注与支持我的博客。您的每一份鼓励都是我前行的动力。若我的文章曾给您带来收获或启发,欢迎打赏支持。打赏款项将用于提升内容质量,为您提供更优质的阅读体验。无论结果如何,都感恩您的陪伴,让我们共同在知识的世界里探索前行!



目录
相关文章
|
19天前
|
移动开发 小程序 前端开发
几千怎么部署搭建校园服务平台,校园圈子论坛系统小程序搭建,校园系统源码,多种功能一体的综合性校园平台
校园圈子论坛是一款集交友、二手市场、聊天等多功能于一体的校园社交平台,支持App、小程序和H5三端交付。学生可处理闲置物品、结识新朋友,通过算法匹配兴趣相投的用户。平台提供分享邀请机制,支持自动绑定推荐关系,并设有奖励机制。开发过程中需注重数据安全与系统稳定性,确保功能兼容及性能优化。
61 5
|
19天前
|
移动开发 小程序 前端开发
使用php开发圈子系统特点,如何获取圈子系统源码,社交圈子运营以及圈子系统的功能特点,圈子系统,允许二开,免费源码,APP 小程序 H5
开发一个圈子系统(也称为社交网络或社群系统)可以是一个复杂但非常有趣的项目。以下是一些关键特点和步骤,帮助你理解如何开发、获取源码以及运营一个圈子系统。
96 3
|
22天前
|
小程序 安全 搜索推荐
陪玩小程序的搭建解析与功能需求
陪玩小程序是为玩家提供专业陪玩服务的应用,嵌入社交或游戏平台,具备智能匹配、实时聊天、预约服务等功能,支持便捷高效的游戏体验。源码交付时需提供详细文档、技术支持及定制开发服务,确保客户能顺利维护和升级。选择陪玩小程序时应关注功能需求、用户体验、安全性和成本效益,以确保最佳使用效果。
38 0
|
19天前
|
小程序 安全 网络安全
清晰易懂!陪玩系统源码搭建的核心功能,陪玩小程序、陪玩app的搭建步骤!
陪玩系统源码包含多种约单方式、实时语音互动、直播间与聊天室、大神申请与抢单、动态互动与社交及在线支付与评价等核心功能。搭建步骤包括环境准备、源码上传与解压、数据库配置、域名与SSL证书绑定、伪静态配置及后台管理。注意事项涵盖源码安全性、二次开发、合规性和技术支持。确保平台安全、合规并提供良好用户体验是关键。
|
2月前
|
小程序 数据挖掘 UED
开发1个上门家政小程序APP系统,都有哪些功能?
在快节奏的现代生活中,家政服务已成为许多家庭的必需品。针对传统家政服务存在的问题,如服务质量不稳定、价格不透明等,我们历时两年开发了一套全新的上门家政系统。该系统通过完善信用体系、提供奖励机制、优化复购体验、多渠道推广和多样化盈利模式,解决了私单、复购、推广和盈利四大痛点,全面提升了服务质量和用户体验,旨在成为家政行业的领导者。
|
3月前
|
存储 自然语言处理 小程序
微信小程序多语言切换神器:简繁体切换功能完全指南
随着全球化的发展,支持多种语言的应用程序愈发重要。本文介绍了如何在微信小程序中实现简体与繁体字体之间的切换功能,以满足不同地区用户的需求。通过创建utils文件夹并编写相应的转换函数,开发者可以方便地实现语言切换,从而提升用户体验。文章中还附带了示例代码和效果图,帮助读者更好地理解和应用这一功能。
134 0
微信小程序多语言切换神器:简繁体切换功能完全指南
|
3月前
|
小程序 Linux Python
查找首字母与Python相关的的英文词汇小程序的续篇---进一步功能完善
查找首字母与Python相关的的英文词汇小程序的续篇---进一步功能完善
34 1
|
4月前
|
算法 JavaScript 前端开发
切西瓜法实现微信抢红包功能
该文章介绍了使用“切西瓜法”和“栅栏法”两种算法来模拟微信抢红包的随机分配机制,并通过具体的JavaScript代码实现了红包金额的公平随机分配过程。
切西瓜法实现微信抢红包功能
|
4月前
|
人工智能 前端开发 JavaScript
MacTalk 测评通义灵码,实现“微信表情”小功能
墨问西东创始人池建强分享了团队使用通义灵码的经验。
|
4月前
|
小程序 API 开发工具
使用python 实现微信签到提醒功能
【9月更文挑战第4天】使用python 实现微信签到提醒功能
96 2