java前端传参奇数乱码、双数正常。排除和解决办法

java前端传参奇数乱码、双数正常。排除和解决办法

1.问题描述:
  1. 前台向后台传输数据、奇数中文乱码
  2. 前台格式已经定义:aplication/json;charset=utf-8
2.排查步骤:
  1. 前端console.log()打印、浏览器F12再次查看请求参数是否是中文,编码是否utf-8

  2. controller检查,debug在controller入口去参数时检查是否是中文乱码

  3. 去web.xml中检查过滤器(转码一般没人会写在拦截器吧)

     <filter>
     	<filter-name>CharacterEncodingFilter</filter-name>
     	<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
     	<init-param>
     		<param-name>encoding</param-name>
     		<param-value>utf-8</param-value>
     	</init-param>
     </filter>
    
  4. 一般会有这种默认的字符编码拦截器,但是我这还有一个paramfliter,对所有参数进行过滤转码。

     public class ParameterFilter implements Filter {
     	@Override
     	public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
     			throws IOException, ServletException {
     		JSONRequestWrapper myRequestWrapper = new JSONRequestWrapper((HttpServletRequest) request);
     	}
     	chain.doFilter(myRequestWrapper, response);
     }
    
  5. 发现myRequestWrapper.body乱码,对接受到的request的body查看

     void charReader(HttpServletRequest request) {
     BufferedReader br = request.getReader();
    
     String str, wholeStr = "";
     while((str = br.readLine()) != null){
         wholeStr += str;
     }
     System.out.println(wholeStr);
     }
    
  6. request的body正常,进入JSONRequestWrapper extend HttpServletRequestWrapper方法

     发现原因:
     bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
     ...
      final ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(body.getBytes());
    
  7. 未对buffer编码进行设置。

     bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
     ...
      final ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(body.getBytes());
    
  8. 对buffer进行编码:任然报错
    bufferedReader = new BufferedReader(new InputStreamReader(inputStream),“UTF-8”);

    final ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(body.getBytes(“UTF-8”));

  9. 复制了以前的项目的JSONrequestWrapper,发现utf-8是小写的,解决问题

  10. 用StandardCharset.UTF_8替换"utf-8"

总结

这是我解决这次单数报错的步骤。
其实还是因为GBK转UTF-8字节的问题
之前安卓中文传参也遇到一个中文乱码
解决方法是:

string a ="GBK编码";
string b = new String(a.getbyte(),"ISO-8859-1");
string c = new String(b.getbyte(),"utf-8");

这儿没这样处理的原因就是因为发过来的其实是utf-8,但是项目的属性是GBK,所以直接用utf-8转就好。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值