Cosmos DB只读密钥会引发授权错误
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Cosmos DB只读密钥会引发授权错误相关的知识,希望对你有一定的参考价值。
我试图使用以下代码使用CosmosDb collection
和Primary Key
从Primary Read Only Key
读取文档。
DocumentClient _documentRUClient = new DocumentClient(new Uri(EndPointURI), PrimaryKey);
DocumentClient _documentRClient = new DocumentClient(new Uri(EndPointURI),
ReadOnly_PrimaryKey);
var result = _documentRUClient.CreateDocumentQuery<T>
(UriFactory.CreateDocumentCollectionUri(DataBaseId, CollectionId),
new FeedOptions() { EnableCrossPartitionQuery = true}).AsEnumerable().ToList();
var result2 = _documentRClient.CreateDocumentQuery<T>
(UriFactory.CreateDocumentCollectionUri(DataBaseId, CollectionId),
new FeedOptions() { EnableCrossPartitionQuery = true}).AsEnumerable().ToList();
使用DocumentClient
的Primary Key
从Cosmos DB集合中检索文档而没有任何问题。但是使用Primary Read Only Key
的那个引发了以下错误。
输入授权令牌无法提供请求。请检查是否按照协议构建了预期的有效负载,并检查正在使用的密钥。服务器使用以下有效负载进行签名:'get
星期六,03。2018 06:47:04 GMT
'ActivityId:d57786a0-f7a0-46e9-9375-d5251b81b1e3,Microsoft.Azure.Documents.Common / 1.20.108.4,documentdb-dotnet-sdk / 1.20.2 Host / 64-bit MicrosoftWindowsNT / 10.0.16299.0
如何克服这个问题?
当我设置了错误的只读键时,我重现了你的问题。
示例代码:
using Microsoft.Azure.Documents.Client;
using System;
using System.Linq;
namespace ConsoleApp2
{
class Program
{
private static DocumentClient client;
static string endpoint = "https://***.documents.azure.com:443/";
static string key1 = "***";
static string DataBaseId = "db";
static string CollectionId = "coll";
static void Main(string[] args)
{
client = new DocumentClient(new Uri(endpoint), key1);
var result = client.CreateDocumentQuery
(UriFactory.CreateDocumentCollectionUri(DataBaseId, CollectionId),
new FeedOptions() { EnableCrossPartitionQuery = true }).AsEnumerable().ToList();
Console.WriteLine("aaa");
Console.ReadLine();
}
}
}
返回消息:
我建议您通过Fiddler捕获消息并检查您的只读密钥是否正确。
希望它能帮到你。
以上是关于Cosmos DB只读密钥会引发授权错误的主要内容,如果未能解决你的问题,请参考以下文章
Cosmos db Rest API - 错误 401 未经授权
在 cosmos db 和 asp.net core 中处理请求时发生未处理的异常
Cosmos DB,如果我在使用 SkipToken 查询时更新某些项目会发生啥?
无法使用 Microsoft.EntityFrameworkCore.Cosmos 连接到 Azure Cosmos Db 帐户 - 响应状态代码