Java中各类中文乱码问题解决方法总汇

本文总结了在开发过程中遇到中文乱码的多种解决方案,包括字节数组编码、指定字符编码及UTF-8编码解码等,并针对特殊字符处理提供了实用技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        在我们开发的过程中出现中文乱码是经常可能出现的问题,但是解决方法也各种各样,在此总结一下解决方法和各种方法中可能出现的问题

一、将字节数组进行相应的编码

String  str = "我是一段中文Code";

//1、使用默认的字符编码 ,注意Charset.defaultCharset()的编码格式由系统默认的语言决定,中国默认的是GBK编码

String message = new String(str.getBytes(), Charset.defaultCharset());

//不指定编码格式,默认使用的就是Charset.defaultCharset()

String message = new String(str.getBytes());

//2、指定具体的字符编码

String message = new String(str.getBytes(), "UTF-8");

//3、根据传入的编码格式解析后转成指定字符编码

String message = new String(str.getBytes("GBK"), "UTF-8");

二、对传输数据进行UTF-8编码和解码

String  str = "我是一段中文Code";

//进行UTF-8编码

String utf8Msg = URLEncoder.encode(str , "UTF-8");

//对字符进行UTF-8解码

String message = URLDecoder.decode(utf8Msg ,"UTF-8");

注意:在解码的过程中,如果参数中存在%时,解码会出现一下异常

  1. Exception in thread "main" java.lang.IllegalArgumentException: URLDecoder: Illegal hex characters in escape (%) pattern - For input string: "u9"  
  2.     at java.net.URLDecoder.decode(URLDecoder.java:194)  
  3.     at com.hbzx.controller.PayResultController.main(PayResultController.java:253)

解决办法:使用%25替换字符串中的%号

utf8Msg = utf8Msg .replaceAll("%(?![0-9a-fA-F]{2})", "%25");

String message = URLDecoder.decode(utf8Msg ,"UTF-8");



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明天的地平线

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值