作者:手机用户2602914627 | 来源:互联网 | 2023-09-07 14:18
这篇文章将会带大家使用客户端来请求云函数我们的视频教程(免费)链接为https://static-b5208986-2c02-437e-9a27-cfeba1779ced.bs
这篇文章将会带大家使用客户端来请求云函数
我们的视频教程(免费)链接为https://static-b5208986-2c02-437e-9a27-cfeba1779ced.bspapp.com/
由于考研所以可能文章比较短也是为了拆分每一步操作
我们简单的来做个登录注册退出~
为了方便演示,我们在一个(vue文件)页面文件里面来写
云函数代码
'use strict';
const uniIDs = require('uni-id')
exports.main = async (event, context) => {
let res = {
};
let params = event.params ? event.params : {
};
const uniID = uniIDs.createInstance({
context: context
})
const noNeedTokens = ['login', 'register', 'logout'];
if (noNeedTokens.indexOf(event.action) == -1) {
if (!event.uniIdToken) {
res = {
code: 403,
message: "未携带token"
}
return res;
} else {
let check_user = await uniID.checkToken(event.uniIdToken, {
});
if (check_user.code === 0) {
params.uid = check_user.uid;
} else {
res = check_user;
return res;
}
}
}
switch (event.action) {
case 'register': {
const {
username,
password
} = params;
res = await uniID.register({
username,
password
})
break;
}
case 'login': {
const {
username,
password
} = params;
res = await uniID.login({
username,
password,
queryField: ['username', 'email', 'mobile']
})
break;
}
case 'logout': {
res = await uniID.logout(event.uniIdToken);
break;
}
default: {
res = {
code: 402,
message: "请求非法"
}
break;
}
}
//返回数据给客户端
return res;
};
客户端调用
完整代码(下面分步讲解)
{
{
token}}
封装请求
req(action, params) {
return new Promise((resolve, reject) => {
uniCloud.callFunction({
name: 'user-center',
data: {
action,
params
},
success: res => {
resolve(res.result)
},
fail: res => {
reject(res.result)
}
})
})
}
由于本次只用了user-center云函数 所以name属性我固定了
登录
传参为用户名密码
登录成功将token保存为uni_id_token
则请求时会默认携带
login() {
this.req("login", {
username: this.username,
password: this.password
}).then(res => {
console.log(res);
uni.setStorageSync('uni_id_token', res.token);
uni.setStorageSync('uni_id_token_expired', res.tokenExpired);
this.token = res.token;
})
}
注册
传参为用户名密码
注册成功会默认登录
register() {
this.req("register", {
username: this.username,
password: this.password
}).then(res => {
console.log(res);
uni.setStorageSync('uni_id_token', res.token);
uni.setStorageSync('uni_id_token_expired', res.tokenExpired);
this.token = res.token;
})
}
退出
传参为uni_id_token
logout() {
this.req("logout", {
}).then(res => {
console.log(res);
this.token = "";
})
}
结语
这里并没有处理错误情况
code为0为请求成功你学会了吗~