String和input Stream的转换问题

问题的背景是需求要生成一个文件动态生成下载,我为了偷懒,采用了生成字符串,然后转成inputsteam流输出,

参考了别人的代码如下:

写道
1. String --> InputStream

Java代码
InputStream StringToInputStream(String str){
ByteArrayInputStream stream = new ByteArrayInputStream(str.getBytes());
return stream;
}

InputStream StringToInputStream(String str){
ByteArrayInputStream stream = new ByteArrayInputStream(str.getBytes());
return stream;
}

2. InputStream --> String

Java代码
String inputStreamToString(InputStream is){
BufferedReader in = new BufferedReader(new InputStreamReader(is));
StringBuffer buffer = new StringBuffer();
String line = "";
while ((line = in.readLine()) != null){
buffer.append(line);
}
return buffer.toString();
}

 但是在实际string转的过程InputStream 中,会发现生成的文件中中文出现乱码,这个情况,主要是因为胃这句代码:

ByteArrayInputStream stream = new ByteArrayInputStream(str.getBytes());

因为是把str.getBytes()了,所以string转换成的字节为utf-8,所以改成

ByteArrayInputStream stream = new ByteArrayInputStream(str.getBytes("gbk"));

 

改成gbk就可以了,下面附录写java常见的编码格式,大家如果有类似的字符串问题,就在中间转化下:

写道
Charset
描述

US-ASCII 7 位 ASCII 字符,也叫作 ISO646-US、Unicode 字符集的基本拉丁块
ISO-8859-1 ISO 拉丁字母表 No.1,也叫作 ISO-LATIN-1
UTF-8 8 位 UCS 转换格式
UTF-16BE 16 位 UCS 转换格式,Big Endian(最低地址存放高位字节)字节顺序
UTF-16LE 16 位 UCS 转换格式,Little-endian(最高地址存放低位字节)字节顺序
UTF-16 16 位 UCS 转换格式,字节顺序由可选的字节顺序标记来标识

 

 

你可能感兴趣的:(String)