因为 HttpUtility.UrlEncode 在 Encode 的时候, 将空格转换成加号"+", 在 Decod
e 的时候将"+"号转为空格, 但是浏览器是不能理解"+"号为空格的, 所以如果文件名包含
了空格, 在浏览器下载得到的文件, 空格就变成了"+"号.
e 的时候将"+"号转为空格, 但是浏览器是不能理解"+"号为空格的, 所以如果文件名包含
了空格, 在浏览器下载得到的文件, 空格就变成了"+"号.
一个解决办法是, 在 HttpUtility 的 UrlEncode 之后, 将 "+" 再手动替换成 "%20"( 如果原
来是 "+" 则被转换成 "%2b" ) , 如:
-
//将URL进行编码转换,然后获取URL public static string GetURL(string url) { string URLcode = ""; URLcode = HttpUtility.UrlEncode(url,Encoding.UTF8); //+号替换成空格 URLcode = URLcode.Replace("+", "%20"); //原来是+好的还原 URLcode = URLcode.Replace("%2b","+"); return URLcode; } -
在RUL编码时,如果某些特定的字符不需要转码,在转换前判断,或者转换后替换为原来的字符
本文介绍了一个关于HTTP URL编码的问题,即当文件名包含空格时,使用HttpUtility.UrlEncode方法会将空格错误地编码为加号,导致浏览器下载的文件名中的空格变成加号。文章提供了一种解决方案:通过替换操作确保正确的编码。
7731

被折叠的 条评论
为什么被折叠?



