C#Byte []到Url友好字符串

Lor*_*nVS 27 c# base64 friendly-url

我正在为一个我正在整理的简单网站开发快速验证码生成器,我希望在页面的URL中传递加密密钥.我可能很容易做到这一点作为一个查询字符串参数,但我希望不是这样(只是因为没有其他任何东西跑掉查询字符串)...

我的加密代码生成一个byte [],然后使用Convert.ToBase64String(byte [])将其转换为字符串.但是,这个字符串仍然不是友好的url,因为它可以包含'/'和'='之类的东西.有没有人知道.NET框架中更好的函数将字节数组转换为url友好字符串?

我知道所有关于System.Web.HttpUtility.UrlEncode()及其等价物,但是,它们只适用于查询字符串参数.如果我在路径内部对"="进行url编码,我的Web服务器会返回400 Bad Request错误.

无论如何,不​​是一个关键问题,但希望有人能给我一个很好的解决方案

**编辑:只是为了绝对确定我正在用字符串做什么,我想我会提供更多信息.

由我的加密算法产生的byte []应该通过某种算法提供,以使其成为url友好字符串.在此之后,它将成为XElement的内容,然后将其用作XSLT转换的源文档,并用作锚点的href属性的一部分.我不相信xslt转换导致问题,因为路径上出现的内容似乎是编码的查询字符串参数,但会导致HTTP 400

我也在base64字符串上尝试过HttpUtility.UrlPathEncode(),但这似乎也没有做到(我仍然在我的网址中以'/'结尾)**

ori*_*rip 89

你正在寻找,HttpServerUtility.UrlTokenEncodeHttpServerUtility.UrlTokenDecodeSystem.Web.

它们在base64中编码,用' - '和'_'替换潜在危险的'+'和'/'字符.

MSDN文档

  • 工作就像一个魅力......邪恶(鲜为人知)在那里发挥作用......谢谢你 (2认同)
  • 微软选择将它放在`System.Web`程序集中是多么令人讨厌.叹. (2认同)
  • **谨慎使用**,因为 UrlTokenEncode 在末尾添加了一个数字,表示被删除的 = 符号的数量。在此处查看可能的解决方案 [链接](https://codeday.me/en/qa/20190316/14910.html) (2认同)

小智 5

对于 ASP.NET Core 6.0+ 使用Microsoft.AspNetCore.WebUtilities.WebEncoders

byte[] bytes = RandomNumberGenerator.GetBytes(64);

string encoded = WebEncoders.Base64UrlEncode(bytes);
byte[] decoded = WebEncoders.Base64UrlDecode(encoded);
Run Code Online (Sandbox Code Playgroud)