policy-tcb.md 4.5 KB
Newer Older
Q
qiang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
## 简介

**本文档是腾讯云自定义登录的配套权限说明问题。uniCloud中并不推荐这种用法,[详见](/uniCloud/authentication)。**

如需在前端直接删除云存储,那么为了数据安全,需要一套权限规则,开发者可以在uniCloud web控制台上自定义安全规则,限制**客户端**对云存储的访问权限。本文档主要介绍如何配置安全规则以及表达式的相关说明。

**注意**

- 权限控制仅针对客户端

## 安全规则示例

**规则示例**

```
// 云存储
// 所有人可读,仅创建者可写
{
  "read": true,
  "write": "resource.openid == auth.uid"
}
// 非匿名用户可读,仅创建者可写
{
  "read": "auth.loginType != 'ANONYMOUS'",
  "write": "resource.openid == auth.uid"
}
```

以上 json 配置中解释如下:

- key:指用户的操作类型。
- value:指一个表达式。

## 配置说明

开发者可以在uniCloud控制台设置云存储权限。如下图所示,可以使用默认的四条规则,也可以点击`切换到安全规则`自行配置JSON格式的权限规则。

**关于创建者的说明**

- 如果没有使用云token,那么每次客户端开启都会让用户匿名登录,即每次用户都会拥有一个临时身份。如果用户在一个临时身份下上传了文件,这个文件的创建者就是这个临时身份,用户重新打开应用再次获取的临时身份无法确保与上次的临时身份一致。如果需要配置创建者权限,建议使用云token。

![](https://img.cdn.aliyun.dcloud.net.cn/uni-app/uniCloud/uniCloud-tcb-storage-policy.png)

## 云存储操作类型

|操作类型	|说明											|默认值	|
|:-:			|:-:											|:-:		|
|read			|读取文件,例如:getTempFileURL	|-			|
|write		|上传/覆盖文件,删除文件	|-			|

## 表达式

表达式是伪代码的语句,配置的时候不能过长。

### 变量

**全局变量**

|变量名		|类型		|说明																				|
|:-:			|:-:		|:-:																				|
|auth			|object	|用户登录信息,字段说明参见下文							|
|now			|number	|当前时间的时间戳														|
|resource	|object	|云存储资源																	|
|doc			|any		|数据库文档资源(目前不开放数据库权限配置)	|

**auth**

|字段名		|类型		|说明																												|
|:-:			|:-:		|:-:																												|
|loginType|string	|登录方式,取值为ANONYMOUS(匿名登录)、CUSTOM(自定义登录)|
|uid			|string	|用户唯一 ID(对应云存储的resource.openid),见下面示例			|

**resource**

|字段名	|类型		|说明										|
|:-:		|:-:		|:-:										|
|openid	|string	|资源创建者的用户唯一ID	|

```
//云存储
{
  "read": "resource.openid == auth.uid", //仅创建者可读
  "write": "resource.openid == auth.uid" //仅创建者可写
}
```

### 运算符

|运算符				|说明																								|示例																							|示例解释(集合查询)														|
|:-:					|:-:																								|:-:																							|:-:																						|
|==						|等于																								|auth.uid == 'zzz'																|用户的 uid 为 zzz															|
|!=						|不等于																							|auth.uid != 'zzz'																|用户的 uid 不为 zzz														|
|>						|大于																								|doc.age>10																				|查询条件的 age 属性大于10											|
|>=						|大于等于																						|doc.age>=10																			|查询条件的 age 属性大于等于10									|
|<						|小于																								|doc.age>10																				|查询条件的 age 属性小于10											|
|<=						|小于等于																						|doc.age>=10																			|查询条件的 age 属性小于等于10									|
|in						|存在于集合中																				|auth.uid in ['zzz','aaa']												|用户的 uid 是['zzz','aaa']中的一个							|
|!(xx in [])	|不存在于集合中,使用 in 的方式描述 !(a in [1,2,3])	|!(auth.uid in ['zzz','aaa'])											|用户的 uid 不是['zzz','aaa']中的任何一个				|
|&&						|与																									|auth.uid == 'zzz' && resource.openid == 'xxx'		|用户的 uid 为 zzz 并且资源的创建者id为 xxx	|
|&#124;&#124;	|或者																								|auth.uid == 'zzz' &#124;&#124; auth.uid == 'xxx'	|用户的 uid 为 zzz 或者用户的 uid 为 xxx				|
|.						|对象元素访问符																			|auth.uid																					|用户的 uid																			|

**注意**

- 比较运算符的右值必须为数值。