1

我想知道是否有办法确定连接到 Azure DocumentDB 时使用的授权密钥级别。

主要是为了防止在提供只读授权密钥时尝试创建文档或修改文档。

类似的东西

static async void LogIn(string url, string authKey)
{
    DocumentClient client = new DocumentClient(new Uri(url), authKey);
    if(?clientpermissions?== PermissionMode.Read)
    { Console.WriteLine("You are in read-only mode."); }
}

我看到用户类有一个可以访问的权限对象,但是当纯粹使用身份验证密钥时,我有点迷失了。

我曾考虑尝试创建一个文档并查看是否存在异常,但我真的不喜欢使用失败作为条件似乎是不好的做法。

这里的目标是一种管理文档数据库的工具(我知道一些已经存在,这更多是为了锻炼我的技能)。因此,沿着这些思路,有人试图使用他们获得的密钥访问数据库,他们可能会或可能不会获得 rw 密钥,其中他们也可能不知道权限。理想情况下,可以显示一个标签或指示器来说明他们的访问级别。谢谢!

4

1 回答 1

0

客户端是使用授权密钥构建的,此时没有比您更多的信息。这只是一个字符串。

您可以利用DocumentClient.ReadPermissionAsync方法来获取资源的权限。我没有亲自尝试过,但可能很好探索。

但是,您不妨尝试读/写您所追求的原始文档,并在适用时捕获异常,因为权限有限。这是因为您无论如何都需要提出请求才能获得权限。

我不知道你为什么要做你正在做的事情,但是,我会退后一步问问你自己,你是否可以确保你有正确的密钥来进行你想要的读/写操作去做。

高温高压

于 2015-01-22T03:12:20.080 回答