在java中,如何将utf8 十六进制编码转换成汉字?

用java程序将我爱你中国!转换成汉字
我爱你中国!
请哪位高手帮帮忙,源码,谢谢
我爱你中国!

当在基于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为转换之后的结果
你试着改写成自己需要的代码
温馨提示:答案为网友推荐,仅供参考
第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");