{% import "/cloud-function/node-sdk/macro/total_count.md" as totalCount %} {% macro modifiableField() %} 支持更新的字段:
-
_userprofile
表所有用户定义字段 -
nickname
-
gender
-
country
-
province
-
city
-
language
-
avatar
{% endmacro %}
let MyUser = new BaaS.User()
info SDK >= 3.9
1.本地创建用户
let user = MyUser.create()
2.为上面创建的用户设置属性
user.set(data)
该方法支持两种类型的赋值操作:
a.一次性赋值:
user.set({
key1: value1,
key2: value2
})
b.逐个赋值
user.set(key1, value1)
user.set(key2, value2)
支持的属性:
属性 | 类型 | 必填 | 说明 |
---|---|---|---|
_username | String | _username 、_phone 、_email 、_provider 其中至少一项必填 |
用户名 |
_phone | String | _username 、_phone 、_email 、_provider 其中至少一项必填 |
手机号 |
_email | String | _username 、_phone 、_email 、_provider 其中至少一项必填 |
邮箱 |
_provider | Object | _username 、_phone 、_email 、_provider 其中至少一项必填 |
用户在平台方的用户信息,具体用法请参考 _provider 传入说明 |
_password | String | 传入了 _username 、_email 时必填 |
密码 |
_phone_verified | Boolean | 否 | 手机号是否已验证 |
_email_verified | Boolean | 否 | 邮箱是否已验证 |
avatar | String | 否 | 用户头像 |
nickname | String | 否 | 用户昵称 |
gender | Integer | 否 | 用户性别,可选值包括:0(未知)、1(男性)、2(女性) |
country | String | 否 | 国家 |
province | String | 否 | 省份 |
city | String | 否 | 城市 |
language | String | 否 | 语言 |
is_authorized | Boolean | 否 | 微信是否授权,默认为 undefined |
除了以上字段外,还支持用户表的自定义字段
info 对同一字段进行多次
set
操作,后面的数据会覆盖掉前面的数据
_provider 传入说明
在传入 _provider
的时候,如传入的参数不符合规范,则不会写入数据库中,正确的格式如下:
{
'_provider': {
'platform': {
'keyword': ''
}
}
}
info 在传入了 _provider 的同时,也传入了
_username
,_email
其中一个,则必须传入有效的_password
keyword
必须传入平台支持的有效值:[openid, unionid, user_id]
。
而 platform
必须在支持的平台范围内,目前支持的平台如下:
名称 | 平台 | keyword 有效值 |
---|---|---|
微信小程序 | openid ,unionid (非必填) |
|
qq_miniapp | QQ 小程序 | openid |
baidu_miniapp | 百度小程序 | openid |
douyin | 抖音小程序 | openid |
toutiao | 头条小程序 | openid |
bytedance_devtools | 字节跳动小程序开发者工具 | openid |
news_article_lite | 头条极速版小程序 | openid |
jd_miniapp | 京东小程序 | openid |
alipay | 支付宝小程序 | user_id |
oauth_wechat_mp | 微信公众号 | openid ,unionid (非必填) |
oauth_wechat_web | 微信网页版 | openid ,unionid (非必填) |
oauth_weibo | 微博用户 | openid |
oauth_weibo_native | 微博客户端 | openid |
oauth_wechat_native | 微信客户端 | openid ,unionid (非必填) |
oauth_apple_native | 苹果客户端 | openid |
4.将创建的用户保存到服务器
user.save()
通过上面的四个步骤,即完成了一个用户的创建。
请求示例
const MyUser = new BaaS.User()
const user = MyUser.create()
user.set({
_email: '***',
_password: '***',
})
const res = await user.save()
返回示例
{
"status": 200,
"data": {
"_email_verified": false,
"_group": [],
"_phone_verified": false,
"_provider": {},
"_email": "***",
"avatar": "https://media.ifanrusercontent.com/hydrogen/default_avatar.png",
"can_send_alipay_template_message": false,
"can_send_wechat_template_message": false,
"created_at": 1590463229,
"created_by": 180889312739596,
"id": 180889312739596,
"updated_at": 1590463229,
}
}
MyUser.get(userID)
参数说明
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
userID | Number | 是 | 用户 ID (对应 _userprofile 表中的 id 字段) |
返回字段说明
参数 | 类型 | 说明 |
---|---|---|
avatar | String | 用户头像 |
city | String | 用户所在城市 |
country | String | 用户所在国家 |
gender | String | 用户的性别,值为 1 时是男性,值为 2 时是女性,值为 0 时是未知 |
id | Number | 用户 ID (对应 _userprofile 表中的 id 字段) |
language | String | 用户的语言,简体中文为 zh_CN |
nickname | String | 用户昵称 |
openid | String | 用户唯一标识,由微信生成 |
province | String | 用户所在省份 |
unionid | String | 用户在开放平台的唯一标识符,由微信生成 |
_email | String | 用户邮箱(用于用户以邮箱 & 密码登录) |
_username | String | 用户名(用于用户以用户名 & 密码登录) |
_email_verified | Boolean | 用户邮箱是否已经通过验证(已验证邮箱才能找回密码) |
_provider | Object | 用户在平台方的用户信息 |
_provider.alipay | Object | 支付宝平台的用户信息,见下方说明 |
支付宝平台的用户信息对象说明
参数 | 类型 | 说明 |
---|---|---|
user_id | string | 支付宝小程序用户 user_id |
is_student | boolean | 用户是否是学生 |
user_type | string | 用户类型,包括:company_account(公司账户)以及 personal_account (个人账户) |
user_status | boolean | 用户状态,包括:registered(快速注册用户)、authenticated(已认证用户)、frozen(被冻结用户) 以及inactive(已注册,未激活用户) |
verified | boolean | 用户是否通过实名认证,当且仅当该值为 true 时gender 值才保证准确性 |
avatar | string | 支付宝小程序用户头像 |
province | string | 支付宝小程序用户省份 |
city | string | 支付宝小程序用户市名称 |
nickname | string | 支付宝小程序用户昵称 |
gender | string | 支付宝小程序用户性别,female 为女性,male 为男性 |
info 如果有自定义字段,则一并返回
请求示例
let MyUser = new BaaS.User()
let userID = 36395395
MyUser.get(userID).then(res => {
// success
}, err => {
// err
})
返回示例
{
"status": 200,
"data": {
"id": 5123461461,
"avatar": "http://cdn.ifanr.cn/ifanr/default_avatar.png",
"nickname": "riDGldYXLHouWIYx",
"_username": "myusername",
"_email": "[email protected]",
"_email_verified": false,
"_provider": {
"alipay": {
"avatar": "http://tfsimg.alipay.com/images/partner/T1uIxXXbpXXXXXXXX",
"province": "安徽省",
"city": "安庆",
"nick_name": "支付宝小二",
"is_student": true,
"user_type": "company_account",
"user_status": "authenticated",
"verified": true,
"gender": "female"
}
}
}
}
select 使用方法可以参考数据表 - 字段过滤小节
expand 使用方法可以参考数据表 - 字段扩展小节
请求示例
假设 _userprofile 表中有一个类型为 pointer 的字段,名称为 pointer_test_oder
, 指向了 test_order 表
let MyUser = new BaaS.User()
MyUser.expand(['pointer_test_oder']).select(['nickname', 'pointer_test_order']).get(123456).then((res) => {
// success
}, (err) => {
// err
})
请求结果
{
"status": 200,
"data": {
"pointer_test_order": {
"created_at": 1538966895,
"_table": "test_order",
"id": "5bbac56fbd66033df7fd0aa2",
"created_by": 61736923,
"updated_at": 1538966895
},
"nickname": "ifanrx"
}
}
let MyUser = new wx.BaaS.User()
MyUser.expand(['pointer_test_oder']).select(['nickname', 'pointer_test_order']).find().then((res) => {
// success
}, (err) => {
// err
})
请求结果
{
"status": 200,
"data": {
"meta": {
"next": null,
"offset": 0,
"total_count": 1,
"limit": 20,
"previous": null
},
"objects": [
{
"pointer_test_order": {
"id": "5bbac56fbd66033df7fd0aa2",
"_table": "test_order",
"created_by": 61736923,
"updated_at": 1538966895
},
"nickname": "ifanrx"
}
]
}
}
微信目前对小程序获取用户信息有两个小时的缓存设定,因此,如果一个用户修改了个人信息如头像、昵称等,需两个小时才能重新授权拿到最新的信息。
更新用户信息与数据表更新数据项方法基本一致。
{{modifiableField()}}
请求示例
let MyUser = new BaaS.User()
let userID = 36395395
let user = MyUser.getWithoutData(userID)
// age 为自定义字段
user.set('age', 30).update().then(res => {
// success
}, err => {
// err
})
UserRecord.setAccount({username, email, password})
通过微信、支付宝授权登录用户,可以设置用户名、邮箱、密码,以便下次通过用户名或邮箱登录。
参数说明
名称 | 类型 | 必填 | 说明 |
---|---|---|---|
username | String | N | 用户名 |
String | N | 邮箱 | |
phone | String | N | 手机号 |
password | String | N | 密码 |
示例代码
const MyUser = new BaaS.User()
const userRecord = MyUser.getWithoutData(userID)
userRecord.setAccount({
email: '[email protected]',
username: 'bar',
phone: '15000000000',
password: 'baz',
}).then(res => {
// success
}).catch(err => {
// err
})
返回示例
{
"status": 200,
"data": {
"email": "[email protected]",
"email_verified": false,
"username": "bar",
"phone": "15000000000",
"phone_verified": false,
}
}
BaaS.UserRecord#update(options)
{{modifiableField()}}
参数说明
options:
参数 | 类型 | 必填 | 默认 | 说明 |
---|---|---|---|---|
enableTrigger | boolean | 否 | true | 是否触发触发器 |
withCount | boolean | 否 | true | 是否返回 total_count |
{{totalCount.withCountTips()}}
通过设置自定义查询条件 Query,将符合条件的用户自定义字段进行批量更新操作
注意:由于条件查询可能命中非常多的数据,默认情况下,限制为最多更新前 1000 条数据。 如需要一次性更新更多数据,请通过维护分页来进行。
其中:
请求示例
{% tabs batchUpdateAsync="async/await", batchUpdatePromise="promise" %} {% content "batchUpdateAsync" %}
exports.main = async function batchUpdate() {
try {
let User = new BaaS.User()
let query = new BaaS.Query()
// 设置查询条件(比较、字符串包含、组合等)
...
// limit、offset 可以指定按条件查询命中的数据分页
let userRecords = User.limit(10).offset(0).getWithoutData(query)
// 与更新特定记录一致
userRecords.set(key1, value1)
userRecords.incrementBy(key2, value2)
userRecords.append(key3, value3)
let res = await userRecords.update().then(res => {}, err => {})
console.log(res)
// success
return res
} catch(err) {
//err 为 HError 对象
throw err
}
}
{% content "batchUpdatePromise" %}
// 知晓云后台设置的触发器将不会被触发
function batchUpdate() {
let User = new BaaS.User()
let query = new BaaS.Query()
// 设置查询条件(比较、字符串包含、组合等)
...
// limit、offset 可以指定按条件查询命中的数据分页
let userRecords = User.limit(10).offset(0).getWithoutData(query)
// 与更新特定记录一致
userRecords.set(key1, value1)
userRecords.incrementBy(key2, value2)
userRecords.append(key3, value3)
userRecords.update().then(res => {
console.log(res)
callback(null, res)
}, err => {
//err 为 HError 对象
callback(err)
})
}
{% endtabs %}
返回示例
回调中的 res 对象结构如下:
{
"status": 200,
"data": {
"limit": 1,
"next": "/dserve/v2.1/miniapp/user_profile/?where=%7B%7D&enable_trigger=1&limit=1&offset=1",
"offset": 0,
"operation_result": [
{
"success": {
"id": "5a3c51cdceb616ccfc9d5f78",
"updated_at": 1571044054
}
}
],
"succeed": 1,
"total_count": 402
}
}
不触发触发器的情况下会有以下的行为:
- 当更新命中总条目 <= 1000 时,无论 limit 设置为多少,均为同步更新,将返回每一条更新的 id 和更新结果,详见下方返回示例中同步执行部分。
- 当更新命中总条目 > 1000 时,根据设置 limit 的不同,将有下方两种行为:
- limit <= 1000 时,操作记录为同步执行
- limit > 1000 或未设置时,则会转为异步执行并移除 limit 限制,变成操作全部
{% tabs batchUpdateWithoutTriggerAsync="async/await", batchUpdateWithoutTriggerPromise="promise" %} {% content "batchUpdateWithoutTriggerAsync" %}
exports.main = async function batchUpdate() {
try {
let User = new BaaS.User()
let query = new BaaS.Query()
// 设置查询条件(比较、字符串包含、组合等)
...
// limit、offset 可以指定按条件查询命中的数据分页
let userRecords = User.limit(10).offset(0).getWithoutData(query)
// 与更新特定记录一致
userRecords.set(key1, value1)
userRecords.incrementBy(key2, value2)
userRecords.append(key3, value3)
let res = await userRecords.update({enableTrigger: false}).then(res => {}, err => {})
console.log(res)
// success
return res
} catch(err) {
//err 为 HError 对象
throw err
}
}
{% content "batchUpdateWithoutTriggerPromise" %}
// 知晓云后台设置的触发器将不会被触发
function batchUpdate() {
let User = new BaaS.User()
let query = new BaaS.Query()
// 设置查询条件(比较、字符串包含、组合等)
...
// limit、offset 可以指定按条件查询命中的数据分页
let userRecords = User.limit(10).offset(0).getWithoutData(query)
// 与更新特定记录一致
userRecords.set(key1, value1)
userRecords.incrementBy(key2, value2)
userRecords.append(key3, value3)
userRecords.update({enableTrigger: false}).then(res => {
console.log(res)
callback(null, res)
}, err => {
//err 为 HError 对象
callback(err)
})
}
{% endtabs %}
返回示例
同步操作时,回调中的 res 对象结构如下:
{
"status": 200,
"data": {
"limit": 1,
"next": "/dserve/v2.1/miniapp/user_profile/?where=%7B%7D&enable_trigger=1&limit=1&offset=1",
"offset": 0,
"operation_result": [
{
"success": {
"id": "5a3c51cdceb616ccfc9d5f78",
"updated_at": 1571044054
}
}
],
"succeed": 1,
"total_count": 402
}
}
异步操作时,回调中的 res 对象结构如下:
{
"status": 200,
"data": {
"status": "ok",
"operation_id": 1 // 可以用来查询到最终执行的结果
}
}
info 获取异步执行结果,请查看接口文档
MyUser.delete(userID)
参数说明
名称 | 类型 | 必填 | 说明 |
---|---|---|---|
userID | Number | Y | 用户 ID |
示例代码
const MyUser = new BaaS.User()
User.delete(userID).then(res => {
// success
}).catch(err => {
// err
})
返回示例
{
"status": 204,
"data": ""
}
BaaS.User#count()
{% tabs getUserCountAsync="async/await", getUserCountPromise="promise" %} {% content "getUserCountAsync" %}
let MyUser = new BaaS.User()
let query = new BaaS.Query()
query.contains('nickname', 'like')
let num = await MyUser.setQuery(query).count()
console.log(num) // 10
{% content "getUserCountPromise" %}
let MyUser = new BaaS.User()
let query = new BaaS.Query()
query.contains('nickname', 'like')
MyUser.setQuery(query).count().then(num => {
// success
console.log(num) // 10
callback(null, res)
}, err => {
// err
callback(err)
})
{% endtabs %}
BaaS.User#find(options)
参数说明
options:
参数 | 类型 | 必填 | 默认 | 说明 |
---|---|---|---|---|
withCount | boolean | 否 | true | 是否返回 total_count |
{{totalCount.withCountTips()}}
用户查询与数据表查询方法一致
请求示例
let MyUser = new BaaS.User()
// 查找所有用户
MyUser.find()
// 查询 nickname 中包含 like 的用户
let query = new BaaS.Query()
query.contains('nickname', 'like')
MyUser.setQuery(query).find().then(res => {
// success
}, err => {
// err
})
info _group 是一个系统定义的特殊字段,可以通过 _group 来查询指定用户组下的用户,目前只支持 in 查询。 该字段仅支持查询,不支持删除和修改。
let MyUser = new BaaS.User()
let query = new BaaS.Query()
// 查询用户组 [123, 456, 789] 下的用户
query.in('_group', [123, 456, 789])
MyUser.setQuery(query).find().then(res => {
// success
}, err => {
// err
})
返回示例
成功时 res 结构如下
{
"status": 200,
"data": {
"meta": {
"limit": 20,
"next": null,
"offset": 0,
"previous": null,
"total_count": 3
},
"objects": [
{
"age": 40,
"avatar": "https://media.ifanrusercontent.com/tavatar/f1/e8/f1e8da860635ec7386102a4a9bb5e45857c9369e.jpg",
"city": "Guangzhou",
"country": "China",
"created_at": 1513326300,
"created_by": 36476036,
"gender": 1,
"id": 36476036,
"is_authorized": true,
"language": "zh_CN",
"nickname": "yuky123123",
"openid": "xxxxxxx",
"province": "Guangdong",
"unionid": null,
"updated_at": 1524146181,
"_group": [123],
"user_id": 36476036
}
]
}
}
用户查询排序与数据表排序方法一致,不包含在返回数据里的字段不支持排序,如 created_at。
请求示例
let MyUser = new BaaS.User()
MyUser.orderBy('-nickname').find().then()
用户查询分页与数据表分页方法一致。
请求示例
let MyUser = new BaaS.User()
MyUser.limit(5).offset(10).find().then()
使用 wx.BaaS.User().getWithoutData
可以创建一个 _userprofile 指定数据行的引用。主要配合 pointer 功能使用
let user = new BaaS.User().getWithoutData(123456)
具体使用方法请参考 数据表-添加 pointer 类型数据 小节