主要重视加密与解码的顺序,在后台加密一次,传给前台解码,由于对中文编码的内部处理不一样,会出错,所以应该先加密两次再传输给前台,这样前台接到后第一次解码即可还原后台加密一次的编码(这时再在前台解码一遍,即可得到原始数据),然后在传给后台,后台接收到一次加密的数据后,由于js与java传输的过程会自动编码,然后解码两次,后台即可得到原始数据。
在项目中, 将一个字符串从后台(J2EE项目)传到前台前台页面(html)再传到后台(J2EE项目),
在后台先通过编码(两次):
java代码: java.net.URLDecoder . encode (req.getParameter("value"),"UTF-8");
java.net.URLDecoder . encode (req.getParameter("value"),"UTF-8");
再通过js中的encodeURI函数对字符串进行解密(一次):
js代码: value =decodeURI(value);
然后再后台通过解码(两次):
java代码: java.net.URLDecoder . decode (req.getParameter("value"),"UTF-8");
java.net.URLDecoder . decode (req.getParameter("value"),"UTF-8");
对加密的字符串进行解析就行了!这样就解决了请求中文参数乱码问题!
本文介绍了一种解决前后台中文参数传输过程中出现乱码的方法。核心思路是在后台对中文字符串进行两次加密处理,前端接收后解码一次即可正确显示,再传输回后台时再进行两次解码操作以获取原始数据。

905

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



