uniCloud云开发获取小程序用户openid

目录

一、介绍openid

二、openid获取难在哪

三、云开发获取openid


一、介绍openid

我们在区分小程序用户时都需要用到openid,用户openid就相当于用户在小程序里的身份证。做为用户的唯一标示,所以获取到用户openid就显得很重要了,今天来教大家怎么样获取要用户的唯一标示 openid

二、openid获取难在哪

今天试了网上的很多方法,在真机调试的时候还是能够获取到的,结果一上传代码就获取不到了,应该也有很多同学遇到了这个问题,所以我们应该把code值传到后端去获取openid,因为在前端可能会被抓包或爬取到你的appid和secret,不安全,如果放在后端获取openid,除非你的服务器被攻击了,不然就是安全的。

三、云开发获取openid

1. 首先我们在 uniCloud 目录下的 cloudfunctions 下右击创建云函数

uniCloud云开发获取小程序用户openid_第1张图片

2. 编写云函数

'use strict';  

exports.main = async (event, context) => {
	let appid = "wxc00000000000";//你自己的appid
	let secret = "xxxxxxxxxxxxxxxxxxxxxxxx";//你自己的appsecret
	let url =
	"https://api.weixin.qq.com/sns/jscode2session?appid=" +
	appid +
	"&secret=" +
	secret +
	"&js_code=" +
	event.code +
	"&grant_type=authorization_code";
	let res = await uniCloud.httpclient.request(
		url ,// 请求路径,
		{
			dataType:"json"
		}
	);
	let openid = res.data.openid
	return openid
};

 注意这里的 appid 和 secret 要用你自己的

3. 客户端调用uni.login(),用得到的code调用云函数

uni.login({
    provider: "weixin",
    success: function (res) {
	    uniCloud.callFunction({
		    name: 'openid',
		    data: {
			    code: res.code
		    },
		    success: (res) => {
			    console.log('云函数返回的值::::', res.result)	
		    },
		    fail: () => {
			    console.log('云函数调用失败')
		    }
	    })
	},
});

4. 查看输出

 

现在我们就成功获取到了用户的 openid ,摸着石头过河太难了,都是血泪啊

你可能感兴趣的:(uni-app,前端,javascript,开发语言)