繁体   English   中英

C#-解码字符串不会返回原始编码的字符串

[英]C# - Decoding a string does not return the original encoded one

我有一个随机生成的字符串,需要将其放在URL中,因此我将其编码为:

var encodedToken = System.Web.HttpUtility.UrlEncode(token, System.Text.Encoding.UTF8);

在ASP.NET操作方法中,我收到此令牌并对其进行解码:

var token = System.Web.HttpUtility.UrlDecode(encodedToken, System.Text.Encoding.UTF8);

但是这些标记并不相同。 例如, ab+cd字符串将编码为ab%2bcd ,解码结果将得到ab cd字符串(加号字符变为空白)。

到目前为止,我仅注意到+字符问题,可能还有其他问题。

我该如何解决这个问题?

在您的上下文中,您似乎不需要调用UrlDecode (因为%2b解码为++解码为空白-即您已进行了双重解码)。

鉴于该框架似乎已经为您解码了,您可以删除对UrlDecode的使用。

根据Microsoft文档:

您可以使用UrlEncode方法或UrlPathEncode方法对URL进行编码。 但是,这些方法返回不同的结果。 UrlEncode方法将每个空格字符转换为加号(+)。 UrlPathEncode方法将每个空格字符转换为字符串“%20”,该字符串以十六进制表示形式表示一个空格。 在对URL的路径部分进行编码时,请使用UrlPathEncode方法,以确保解码后的URL一致,无论使用哪种平台或浏览器执行解码。

https://docs.microsoft.com/en-us/dotnet/api/system.web.httputility.urlencode?view=netframework-4.7.2

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM