首页 > 编程语言 >uniapp实现微信小程序一键登录

uniapp实现微信小程序一键登录

时间:2024-10-22 23:19:35浏览次数:3  
标签:uniapp code String openid 微信 APP 一键 hutool

前言

实现微信一键登录的流程:

① 微信小程序端获取临时凭证codecode只能被消费一次

② 将code交给后端

③ 后端拿到code,向微信服务器发起请求,拿到openidopenid代表微信用户在一个小程序中的唯一标识,另外拓展一下unionid代表微信用户在企业中的唯一标识

④ 后端查询数据库是否存在这个openid,存在则登录,返回token;不存在则注册账号,登录,返回token

一、复制 AppID 和 AppSecret

去 微信公众平台 -> 开发与服务 -> 开发管理 :微信公众平台 (qq.com)

复制AppIDAppSecret

三、通过uni.login() 拿到临时凭证code

uni.login({
        provider: 'weixin',
        success: function (loginRes) {
        	//	打印临时凭证
        	console.log(loginRes.code)
    	}
});

 另外,可以通过uni.getUserInfo()获取到用户的头像、昵称、手机号等信息,不过手机号需要企业身份才可以,如:

// 登录成功
uni.getUserInfo({
    provider: 'weixin',
    success: function(info) {
        // 获取用户信息成功, info.authResult是用户信息
        const wxUserInfo = info.userInfo
		//	打印头像url
        console.log(wxUserInfo.avatarUrl)
        //	打印昵称
        console.log(wxUserInfo.nickName)
        //	打印用户详细信息
        console.log(wxUserInfo)
    }
})

四、后端用临时凭证code换取openid

 在spring-web工程中导入maven工具依赖

<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.8.16</version>
</dependency>

在下面工具类中配置自己的AppID,AppSecret后即可使用

import cn.hutool.http.HttpResponse;
import cn.hutool.http.HttpUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import org.springframework.web.util.UriComponentsBuilder;

public class WechatUtil {
	//	配置自己的app_id、app_secret
    private static final String APP_ID = "Your_APP_ID";
    private static final String APP_SECRET = "Your_APP_SERCERT";

    public static String getOpenId(String loginCode) {
        String url = "https://api.weixin.qq.com/sns/jscode2session";
        String requestUrl = UriComponentsBuilder.fromHttpUrl(url)
                .queryParam("appid", APP_ID)
                .queryParam("secret", APP_SECRET)
                .queryParam("js_code", loginCode)
                .queryParam("grant_type", "authorization_code")
                .toUriString();

        HttpResponse response = HttpUtil.createGet(requestUrl).execute();

        // 获取 session_key 和 openid
        JSONObject parseObj = JSONUtil.parseObj(response.body());

        String openid = (String) parseObj.get("openid");
        return openid;
    }
}

 拿到openid之后便可以通过查询数据库实现一键登录了

标签:uniapp,code,String,openid,微信,APP,一键,hutool
From: https://blog.csdn.net/weixin_74261199/article/details/143101210

相关文章

  • 广告---高仿水滴筹源码,全开源uniapp+fastadmin开发
    一、水滴筹系统概述水滴筹是国内知名的大病筹款平台,为众多病患提供了便捷的筹款渠道。该平台不仅具有筹款金额高、筹款速度快、操作简便等特点,还具备强大的社交互动功能,让更多的人参与到公益事业中来。本文将介绍如何基于最新UI仿水滴筹系统源码和全开源UniApp开发,制作出一套......
  • uniapp权限判断
    写法如下//检查是否有写入外部存储的权限functionwriteExternalStoragePermission(){returnnewPromise((resolve,reject)=>{varManifest=plus.android.importClass("android.Manifest");varMainActivity=plus.androi......
  • 海量大模型如何一键部署上云?函数计算 x ModelScope 社区给出答案
    作者:魔搭官方大模型在过去一年多时间里的一路技术狂奔,深刻的改变了今天模型和AI的整体应用生态,也给开发者提供纷繁复杂的模型选择。在多样化大模型的背后,OpenAI得益于在领域的先发优势,其API接口今天也成为了业界的一个事实标准。许多开源工具和框架,包括LlamaIndex,LangChain......
  • 短剧cps小程序开发,源码独立搭建部署,正版短剧小说授权,支持抖音,微信,快手多端分销
    短剧CPS小程序是什么?用来分销推广各平台短剧的系统,系统已对接好他人短剧平台片源,利用小程序获取素材分销链接进行广泛传播,推广给用户能够在第三方小程序里充值观看短剧。 短剧分销系统功能付费观看:跳转第三方单剧付费或会员订阅,获取用户收入。分销佣金:推广者通过推广销售......
  • 拼多多商品详情,一键获取的“魔法”
    亲爱的朋友们,你是否曾在拼多多上看到一件心仪的商品,却因为繁琐的手动操作而望而却步?是否在想,如果能有一种“魔法”,让我们能快速获取商品的详细信息,那该多好!今天,我要告诉你,这种“魔法”真的存在,它就是——PDDAPI!首先,让我们来聊聊拼多多。这个平台以其独特的团购模式和亲民的价格,......
  • VMD-DBO-CNN-BiLSTM四模型多变量时间序列光伏功率预测一键对比 Matlab代码
    基于VMD-DBO-CNN-BiLSTM、VMD-CNN-BiLSTM、VMD-BiLSTM、BiLSTM四模型多变量时间序列光伏功率预测一键对比(仅运行一个main即可)[原创未发表]Matlab代码每个模型的预测结果和组合对比结果都有!运行步骤:1.先运行main1进行VMD分解2.在运行main2进行四模型一键对比代码......
  • 基于NRBO、CPO、TTAO、FVIM-CNN-LSSVM/CNN-LSSVM回归预测 5 模型一键对比 Matlab
    基于NRBO-CNN-LSSVM、CPO-CNN-LSSVM、TTAO-CNN-LSSVM、FVIM-CNN-LSSVM、CNN-LSSVM五模型多变量回归预测一键对比(仅运行一个main即可)Matlab代码代码解释:(优化算法均为24年算法)优化参数为:批次数、正则化系数、学习率【牛顿拉夫逊算法、冠豪猪算法、三角拓扑聚合算法、四向......
  • 抖音小店商家电话采集系统 一键导出抖音商家联系方式软件
    分享作者:1143561141(v同q)抖音作为目前最受欢迎的短视频平台之一,吸引了大量商家在平台上开设小店。许多人希望能够快速获取商家的联系方式,以便合作或咨询产品信息。本教程将介绍如何使用Python编写一个抖音小店商家电话采集系统,通过一键导出商家的联系方式。步骤一:安装必要的工具......
  • 基于SpringBoot+Vue的办公用品管理系统微信小程序(源码+LW+调试文档+讲解)
    基于SpringBoot+Vue的办公用品管理系统是一套功能全面且实用的管理工具。该系统结合了SpringBoot强大的后端处理能力和Vue出色的前端交互体验。通过源码,用户可以深入了解系统的架构和实现细节,方便进行二次开发和定制。LW(可能是某种特定的文档或说明)有助于用户更好地......
  • 移动端页面字体在微信被放大,导致排版错乱
    微信在iOS和Android平台上对网页字体大小的调整机制不同,需要分别处理。以下是如何在PBootCMS中实现这一功能的详细步骤:1.阻止iOS平台上的字体放大在PBootCMS的模板文件中,找到header.html文件(通常位于/template/你的模板名称/目录下),并在<head>标签内添加以下CSS样式:<style>......