第1个回答 2020-07-01
当在基于HTTP协议的JSP或Servlet的应用中获取数据或发送请求时,JVM会把输送的数据编码成UTF8格式。如果我们直接从HTTP流中提取中文数据,提取的结果为“????”(可能更多问号),为转换成我们能够理解的中文字符,我们需要把UTF8转换成GB2312,借助ISO-8859-1标准编码能够轻易的实现,下面的代码实现了这一功能:
byte
[]
b;
String
utf8_value;
utf8_value
=
request.getParameter("NAME");//从HTTP流中取"NAME"的UTF8数据
b
=
utf8_value.getBytes("8859_1");
//中间用ISO-8859-1过渡
String
name
=
new
String(b,
"GB2312");
//转换成GB2312字符
在知道流长度的情况下将输入流转换成字节数组
Java中的输入流抽象类InputStream有int
read(byte[]
b,
int
off,
int
len)方法,参数中byte[]
b是用来存放从InputStream中读取的数据,int
off指定数组b的偏移地址,也就是数组b的起始下标,int
len指定需要读取的长度,方法返回实际读取的字节数。
下面的代码实现了这一功能:
ServletInputStream
inStream
=
request.getInputStream();
//取HTTP请求流
int
size
=
request.getContentLength();
//取HTTP请求流长度
byte[]
buffer
=
new
byte[size];
//用于缓存每次读取的数据
byte[]
in_b
=
new
byte[size];
//用于存放结果的数组
int
count
=
0;
int
rbyte
=
0;
while
(count
<
size)
{
//循环读取
rbyte
=
inStream.read(buffer);
//每次实际读取长度存于rbyte中
for(int
i=0;i<rbyte;i++)
{
in_b[count
+
i]
=
buffer[i];
}
count
+=
rbyte;
}
在不知道流长度的情况下将输入流转换成字节数组
前面介绍了已知流长度的情况下的转换方法,那么当我们不知道流有多长时,也就是说不能确定转换后的字节数组有多大时,该怎么处理呢?笔者查看了JDK文档之后发现ByteArrayOutputStream有一个byte[]
toByteArray()方法,该方法会自动创建一个字节数组,然后返回。于是就巧妙的用ByteArrayOutputStream来作中间过渡实现转换,其它处理跟上面所介绍已知长度的情况差不多。假设需要被转换的流已经放在inStream里了,我们可以用如下的代码实现这一功能:
ByteArrayOutputStream
swapStream
=
new
ByteArrayOutputStream();
byte[]
buff
=
new
byte[100];
//buff用于存放循环读取的临时数据
int
rc
=
0;
while
((rc
=
inStream.read(buff,
0,
100))
>
0)
{
swapStream.write(buff,
0,
rc);
}
byte[]
in_b
=
swapStream.toByteArray();
//in_b为转换之后的结果
你试着改写成自己需要的代码
第2个回答 推荐于2018-05-04
我不知道你的16进制UTF-8编码是哪来的,但明显是定长的UTF-16编码
byte[] b(byte)0x62,(byte)0x11,(byte)0x72,(byte)0x31};
try {
System.out.println(new String(b,"UTF-16"));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}本回答被提问者和网友采纳
第3个回答 2009-05-08
new String("好".getBytes("UTF-8"), "gb2312")
第4个回答 2015-07-28
new string("utf-8","GBK");