[英]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.