前后端交互处理乱码
作者:互联网
encodeURI和decodeURI是成对来使用的,因为浏览器的地址栏有中文字符的话,可以会出现不可预期的错误,所以可以encodeURI把非英文字符转化为英文编码,decodeURI可以用来把字符还原回来。encodeURI方法不会对下列字符进行编码:":"、"/"、";" 和 "?",encodeURIComponent方法可以对这些字符进行编码。
decodeURI()方法相当于java.net.URLDecoder.decode(URIString, "UTF-8");
encodeURI()方法相当于java.net.URLEncoder.encode(URIString, "UTF-8");
如果字符串中存在”+“字符的话,再通过encodeURI进行转码传递给后台的时候,后台通过URLDecoder解析该值时会自动把”+“字符解析为” “空格字符,
如果进行数据库操作的话,解析后的字符串与前台界面传递到后台的字符串会有差异。导致再从数据库读取时,前台通过encodeURI进行转化时有时不
会自动把” “转换为”+“,此问题并不是必现。
解决办法
可以在字符串进行encodeURI转换之前进行特殊操作,例如encodeURI(str).replace(/\+/g,'%2B')把”+“字符替换为'%2B'字符。
例子
js
encodeURIComponent(encodeURIComponent(spymc))
java
java.net.URLDecoder.decode(dto.get("spymc").toString(), "UTF-8");
标签:字符,java,前后,乱码,UTF,net,URLDecoder,交互,encodeURI 来源: https://blog.csdn.net/weixin_40694508/article/details/115343036