实际项目中前后端传输字符串URL编解码过程中遇到的一些问题

Posted CeraSumat

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实际项目中前后端传输字符串URL编解码过程中遇到的一些问题相关的知识,希望对你有一定的参考价值。

线上版本(包括12.2,12.3版本)中,参照过滤条件在传输过程中经过了URL编码及解码过程,前后端使用的API之间的差异导致一些问题,现记录如下:

 


前端URL编码API

 

encodeURIComponent使用UTF-8编码格式对字符串进行URL编码;


后端URL解码API:目前代码中存在以下三种解码方式:

 

System.Web.UI.Server.UrlDecode,存在问题:无法解析%2B为+,输出为空白字符;

Microsoft.JScript.GlobalObject.unescape,存在问题:只能使用Unicode编码格式,与前端API使用的UTF-8编码格式不匹配,具体问题是汉字无法正确解码;

System.Web.HttpUtility.UrlDecode,存在问题:可以指定编码格式,便于与前端API使用的UTF-8编码格式匹配,但对%2B的解码是非幂等的,第一次解码可以被正确解析为+,而对+解码则输出空白字符;

 

 

 

鉴于以上存在的问题,在服务端解码过程中,需要谨慎考虑各种场景下(包括前端、领域)的编解码方式、次数(夹杂BASE64编码)等因素进行解码。

以上是关于实际项目中前后端传输字符串URL编解码过程中遇到的一些问题的主要内容,如果未能解决你的问题,请参考以下文章

Base64编解码是什么?

JS编解码与Java编解码

前后端分类,数据传输问题

url参数中带有中文时出现字符乱码

字符编码与解码

Java前后端分离项目生成二维码链接带中文参数遇到的问题及解决办法