如何解码 .NET Core 中 Azure 搜索索引器生成的 metadata_storage_path
How to decode metadata_storage_path produced by Azure Search indexer in .NET Core
使用.NetCore 1.1.2.
通过 Azure 搜索 SDK 成功获得搜索结果后,我正在尝试解码 metadata_storage_path 值。我见过有人说在 .NET 中使用 HttpServerUtility.UrlTokenDecode 或在其他语言中使用 as seen here.
那么问题就变成了,HttpServerUtility.UrlTokenDecode在.NetCore中的等价物是什么?有:
var pathEncoded = "aHR0cHM6Ly9mYWtlZC5ibG9iLmNvcmUud2luZG93cy5uZXQvcGRmYmxvYnMvYW5udWFsX3JlcG9ydF8yMDA5XzI0NTU20";
我尝试了以下方法:
var pathbytes = Convert.FromBase64String(pathEncoded);
//Throws System.FormatException "Invalid length for a Base-64 char array or string."
和
var pathbytes = WebEncoders.Base64UrlDecode(pathEncoded);
//Throws System.FormatException - "TODO: Malformed input."
有趣的是,如果我切断 pathEncoded 中的最后一个字符,一切都会正常...使用 Microsoft.AspNetCore 1.1.2 处理这种情况的正确方法是什么?
HttpServerUtility.UrlTokenEncode
向编码字符串附加一个额外的尾随字符。你做得对 - 只需删除那个额外的字符并使用 WebEncoders.Base64UrlDecode
。有关详细信息,请参阅 this Q&A。
我在 asp.net 核心 2.1 中使用了以下函数来编码来自 Azure 搜索的 meta_storage_path 值。
private string DecodeBase64String(string encodedString)
{
var encodedStringWithoutTrailingCharacter = encodedString.Substring(0, encodedString.Length - 1);
var encodedBytes = Microsoft.AspNetCore.WebUtilities.WebEncoders.Base64UrlDecode(encodedStringWithoutTrailingCharacter);
return HttpUtility.UrlDecode(encodedBytes, Encoding.UTF8);
}
我只是想补充一点,您也可以取消选择 'Base-64 Encode Keys' Azure 搜索索引器选项。
注意:仅对没有字符的字段执行此操作,Azure 认为对文档密钥无效。
使用.NetCore 1.1.2.
通过 Azure 搜索 SDK 成功获得搜索结果后,我正在尝试解码 metadata_storage_path 值。我见过有人说在 .NET 中使用 HttpServerUtility.UrlTokenDecode 或在其他语言中使用 as seen here.
那么问题就变成了,HttpServerUtility.UrlTokenDecode在.NetCore中的等价物是什么?有:
var pathEncoded = "aHR0cHM6Ly9mYWtlZC5ibG9iLmNvcmUud2luZG93cy5uZXQvcGRmYmxvYnMvYW5udWFsX3JlcG9ydF8yMDA5XzI0NTU20";
我尝试了以下方法:
var pathbytes = Convert.FromBase64String(pathEncoded);
//Throws System.FormatException "Invalid length for a Base-64 char array or string."
和
var pathbytes = WebEncoders.Base64UrlDecode(pathEncoded);
//Throws System.FormatException - "TODO: Malformed input."
有趣的是,如果我切断 pathEncoded 中的最后一个字符,一切都会正常...使用 Microsoft.AspNetCore 1.1.2 处理这种情况的正确方法是什么?
HttpServerUtility.UrlTokenEncode
向编码字符串附加一个额外的尾随字符。你做得对 - 只需删除那个额外的字符并使用 WebEncoders.Base64UrlDecode
。有关详细信息,请参阅 this Q&A。
我在 asp.net 核心 2.1 中使用了以下函数来编码来自 Azure 搜索的 meta_storage_path 值。
private string DecodeBase64String(string encodedString)
{
var encodedStringWithoutTrailingCharacter = encodedString.Substring(0, encodedString.Length - 1);
var encodedBytes = Microsoft.AspNetCore.WebUtilities.WebEncoders.Base64UrlDecode(encodedStringWithoutTrailingCharacter);
return HttpUtility.UrlDecode(encodedBytes, Encoding.UTF8);
}
我只是想补充一点,您也可以取消选择 'Base-64 Encode Keys' Azure 搜索索引器选项。
注意:仅对没有字符的字段执行此操作,Azure 认为对文档密钥无效。