编码乱码问题
// 文件读取时,需要设置编码格式
BufferedReader reader = new BufferedReader(new InputStreamReader(ps.getInputStream(), Charset.forName("GBK")));
reader = new BufferedReader(new InputStreamReader(in, Charset.forName("utf-8")));
BufferedReader reader = new BufferedReader(new InputStreamReader(ps.getInputStream(), Charset.forName("UTF-8")));
// 转换编码格式
System.out.println(new String("你好".getBytes(StandardCharsets.UTF_8)));
System.out.println(new String("你好".getBytes(Charset.forName("GBK"))));
System.out.println(new String("你好".getBytes(Charset.forName("GBK")), StandardCharsets.UTF_8));
System.out.println(new String("浣犲ソ".getBytes(StandardCharsets.UTF_8)));
System.out.println(new String("浣犲ソ".getBytes(Charset.forName("GBK"))));
System.out.println(new String("浣犲ソ".getBytes(Charset.forName("GBK")), StandardCharsets.UTF_8));
// jar包commons.io方式
import org.apache.commons.io.FileUtils
StringWriter writer = new StringWriter(); // 字符串数据
FileUtils.writeStringToFile(new File("文件目录"), writer.toString(), CharsetKit.UTF_8);
// 设置请求以及响应的内容类型
response.setContentType("text/html;charset=utf-8");
Linux中文显示乱码问题解决方法
locale 查看下linux编码
修改方式: 执行脚本的时候加上 export LANG="zh_CN.UTF-8"
数据库乱码
1.mysql乱码问题: 客户端字符集 和 主机字符集 不一致,导致入库数据乱码
客户端登录的时候,设置mysql 的字符集, 同主机保持一致