java exception 乱码_java 常见中文乱码问题解决

本文详细介绍了在Java Web环境中如何避免中文乱码,包括设置jsp页面编码、请求编码以及调整Tomcat配置。同时,针对TXT文件读取时可能出现的乱码问题,提供了一种通过探测文件头来确定字符集的方法,确保读取内容的正确性。
摘要由CSDN通过智能技术生成

关于中文乱码:

一、

1).在jsp页面上输入中文,要保证中文不乱码,有三个前提:

保证contentType=“text/html;charset=UTF-8”,pageEncoding=“UTF-8” charset和pageEncoding的编码一致,且都支持中文,通常建议取值为UTF-8,还需要摆正浏览器的显示的字符编码也和请求的jsp页面的编码一致。

2)、常见问题实例:(比如两个jsp,b.jsp获取a.jsp页面传过来的参数值,method为POST)

a.jsp

pageEncoding="UTF-8"%>

中文乱码

userName:

b.jsp

request.setCharacterEncoding("UTF-8");

%>

获取中文参数值:默认参数在传输过程中使用的编码为ISO-8859-1.

上面方法对get请求无效,在get请求得按下面方式解码转码:

String val = request.getParameter("userName");

String userName = new String(val.getBytes("ISO-8859-1"),"UTF-8");

out.print(userName+"==");

%>

上面方式比较复杂,有种方式可以既适用于get请求又适用于post请求,修改tomcat参数,中文乱码是tomcat的 问题:

首先修改本地tomcat服务器/conf/server.xml中的:

不要忘了在exclipse中也改一下tomcat的映射配置文件server.xml,useBodyEncodingForURI这个属性的意思是使用body里指定的字符编码,比URIEncoding要灵活一点,比如body已经指定了UTF-8,那么上面解码转码的方式还会是乱码,因为这个属性已经指定了字符集utf-8,解码也必须utf-8.

二、解析txt文档乱码。

windows下的文本文件字符集默认是GBK2312/GBK,在使用字符流或字节流读取文本文件的时候,文本文件可能是不同的字符集,比如有ANSI、GBK、UTF-8、Unicode等等,要想读入的数据不乱码,一点要保证读流传入的字符集和文本文件的字符集一致,这样不论文本文件的字符集是什么都可以防止乱码,所以要获取文本文件的字符集,比较专业一点的方法可以去找一下文件探测器,下面介绍一个比较实用的实例:

package com.hnasys.fft.web.component.file.analyze;

import java.io.BufferedInputStream;

import java.io.BufferedReader;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.InputStreamReader;

import java.lang.reflect.Field;

import java.util.LinkedList;

import java.util.List;

import com.hnasys.fft.tool.land.Reflects;

public class TabFileAnalyzer {

public static String codeString(File fileName) throws Exception{

@SuppressWarnings("resource")

BufferedInputStream bin = new BufferedInputStream(new FileInputStream(fileName));

int p = (bin.read() << 8) + bin.read();

String code = null;

switch (p) {

case 0xefbb:

code = "UTF-8";

break;

case 0xfffe:

code = "Unicode";

break;

case 0xfeff:

code = "UTF-16BE";

break;

case 0x5c75:

code = "ANSI|ASCII" ;

break ;

default:

code = "GBK";

}

return code;

}

public static void analyze(File file, List datas, Class beanClass) {

BufferedReader br = null;

List lines = new LinkedList();

try {

try {

//读流时传入所读的文本文件的字符集,这样就可以保持传入的文本文件的字符编码可读入时候所用编码一致

br = new BufferedReader(new InputStreamReader(new FileInputStream(file), codeString(file)));

} catch (Exception e) {

e.printStackTrace();

}

String line = "";

while ((line = br.readLine()) != null) {

if (!line.trim().isEmpty()) {

lines.add(line + " ");

}

}

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

} finally {

try {

br.close();

} catch (IOException e) {

e.printStackTrace();

}

}

for (String line : lines) {

T obj = null;

try {

obj = beanClass.newInstance();

} catch (InstantiationException e) {

throw new RuntimeException("创建对象失败", e);

} catch (IllegalAccessException e) {

throw new RuntimeException("创建对象失败", e);

}

String[] lineCols = line.split("\t");

List fields = Reflects.getFields(beanClass);

for (Field field : fields) {

String value = lineCols[fields.indexOf(field)];

if (value == null)

continue;

value = value.trim();

if ("N/A".equals(value) || value.isEmpty())

continue;

// 实际类型字段值

Object rv = null;

// 设置到对象中

if (field.getType() == String.class)

rv = value;

else if (field.getType() == Integer.class)

rv = Integer.valueOf(value);

else if (field.getType() == Double.class)

rv = Double.valueOf(value);

else

throw new RuntimeException("暂不支持除String、Integer、Double以外的类型");

// 设置到字段中

field.setAccessible(true);

try {

field.set(obj, rv);

} catch (IllegalArgumentException | IllegalAccessException e) {

throw new RuntimeException(e);

}

}

datas.add(obj);

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值