springboot微信小程序 获取微信unionid

流程图

 

创建授权按钮,向后台获取unionid

<template>
	<view style="margin-top: 60%;">  
	<!-- <button type="default" open-type="getUserInfo" @getuserinfo='getuserinfo'>微信授权</button> -->
	
	<view style="text-align: center;">申请获取你的公开信息(昵称,头像等)</view>
	
	
	<button
	      open-type="getUserInfo"
	      withCredentials="true"
	      class="mc btn-auth"
	      @getuserinfo="getUserInfo"
	    >
	      授权登录
	    </button>

	</view>
	
</template>

<script>

		
	export default {
	    data() {
	        return {
				code:"",
				next:"",
	        }
	    },
		onLoad(e) {
			this.next=e.next;
		
			
		},
		onReady() {
			
		},
	    methods: {
			getUserInfo() {
			    // let = {};
				// var that= this
			    let _this = this;
			    uni.login({
			      provider: "weixin",
			      success: (res) => {
			        let code = res.code;
			        uni.getUserInfo({
			          provider: "weixin",
			          lang: "zh_CN",
			          success: function(res) {
						  
						  uni.request({
						  					  url: getApp().globalData.url+'/wechat/login', 
						  					    data: {
						  							rawData:res.rawData,//用户信息
						  							signature:"111",
						  					        code: code,
						  							encryptedData:res.encryptedData,
						  							iv:res.iv,
						  							
						  					    },
						  						method:'POST',
						  					    header: {
						  					        'Content-Type': 'application/json',
						  							
						  					    },
						  					    success: (res) => {
						  						
						  							if(res.data.status==200){
						  								// 添加缓存
						  								uni.setStorage({
						  								    key: 'unionId',
						  								    data: res.data.data.userInfo.unionId,
						  								    success: function () {
						  								        console.log(
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序获取unionid的步骤如下: 1. 开发者在小程序后台配置小程序的AppID、AppSecret以及启用相关的接口权限。 2. 用户在小程序中进行登录,获取到用户的openid和session_key。 3. 利用session_key进行解密,获取到用户的用户敏感数据,其中包括unionid。 4. 使用解密后的unionid,开发者可以将其与用户在小程序中的其他信息进行关联,方便后续业务的处理。 根据上述步骤,下面是一个示例代码片段来实现获取unionid的功能: ```javascript // 根据用户的code获取用户的openid和session_key wx.login({ success: function(res) { if (res.code) { // 发起网络请求,调用后台接口获取openid和session_key wx.request({ url: 'https://api.weixin.qq.com/sns/jscode2session', data: { appid: 'wxXXXXXXXXXXXXXXX', // 小程序的AppID secret: 'XXXXXXXXXXXXXXXXX', // 小程序的AppSecret js_code: res.code, grant_type: 'authorization_code' }, success: function(res) { var openid = res.data.openid; var sessionKey = res.data.session_key; // 解密用户敏感数据,获取unionid var encryptedData = "XXXXXXXXXXXXXXXXX"; // 用户加密的数据 var iv = "XXXXXXXXXXXXXXXXX"; // 加密算法的初始向量 var pc = new WXBizDataCrypt(appId, sessionKey); var data = pc.decryptData(encryptedData , iv); var unionId = data.unionId; // 将unionid与其他用户信息关联存储 // TODO: 进行后续业务处理 } }); } else { console.log('登录失败!' + res.errMsg); } } }); ``` 其中,需要开发者自行实现一个WXBizDataCrypt类,用于解密用户敏感数据,可以参考微信官方提供的相关文档进行实现。 这样,开发者就可以在小程序中获取到用户的unionid,方便后续的用户关联及业务处理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值