c# – 如何解码.NET Core中Azure Search索引器生成的metadata_storage_path

使用.NetCore 1.1.2.

通过Azure Search 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.

相关文章

本文将从上往下,循序渐进的介绍一系列相关.NET的概念,先从...
基于 .NET 的一个全新的、好用的 PHP SDK + Runtime: Pe...
.NET 异步工作原理介绍。
引子 .NET 6 开始初步引入 PGO。PGO 即 Profile Guided Opti...
前言 2021/4/8 .NET 6 Preview 3 发布,这个版本的改进大多来...
前言 开头防杠:.NET 的基础库、语言、运行时团队从来都是相...