java判断文件编码是UTF-8还是UTF-8(BOM)还是其他编码

这段代码演示了如何使用Java来检测文件的编码是否为UTF-8(带BOM或不带BOM)或其他编码。通过UnicodeInputStream和ByteArrayUtil类,分别对比文件内容的字节表示来确定编码类型。

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

java判断文件编码是UTF-8还是UTF-8(BOM)还是其他编码

	final String filePath = "C:\\Users\\小太阳\\Desktop\\java\\20210302~\\mybatis\\mybatis.txt";
	
	BufferedInputStream bis = new BufferedInputStream(new FileInputStream(new File(filePath)),4);
	UnicodeInputStream uis = new UnicodeInputStream(bis);
	byte[] b = FileUtils.readFileToByteArray(new File(filePath));
	byte[] b2 = FileUtils.readFileToString(new File(filePath),Charset.forName("UTF-8")).getBytes(Charset.forName("UTF-8"));
	System.out.println(ByteArrayUtil.toHexString(b));
	System.out.println(ByteArrayUtil.toHexString(b2));
	
	if (uis.getEncodingFromStream() != null && uis.getEncodingFromStream().equals("UTF-8")) {// UTF-8-BOM判断
		System.out.println(uis.getEncodingFromStream() + "-BOM");//UTF-8-BOM:UTF-8;非UTF-8-BOM:null			
	}else if (ByteArrayUtil.toHexString(b).equals(ByteArrayUtil.toHexString(b2))) {//UTF-8判断
		System.out.println("UTF-8");
	}else {
		System.out.println("其他编码");
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值