微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐