「java根据字节生成汉字」java生成字节码文件
今天给各位分享java根据字节生成汉字的知识,其中也会对java生成字节码文件进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
- 1、在java中,如何将utf8 十六进制编码转换成汉字?
- 2、JAVA中,怎样将字母加密成汉字? 我看有人用一个字母与20000异或就变成了汉字。 其中原理是?
- 3、Java中是怎么按字节读取汉字后又拼成汉字的
- 4、java中怎么从byte字节流转换为中文
- 5、Java 明明是字节流为什么能输出汉字???
- 6、java 的byte数组与汉字输出
在java中,如何将utf8 十六进制编码转换成汉字?
当在基于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;irbyte;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为转换之后的结果
你试着改写成自己需要的代码
JAVA中,怎样将字母加密成汉字? 我看有人用一个字母与20000异或就变成了汉字。 其中原理是?
汉字在Java里面用到两个字节(其实都是2个字节 char类型的 不过在流里输入的好像不是)
也就是2^15~2^16-1都可以表示汉字
而20000在这个范围内的 字母的话 前8位是0 所以 字母和20000异或也就是在那个范围内的 可以表示出汉字的 而异或这个操作是可以还原的 用密文异或20000也可以变成原来的字母
Java中是怎么按字节读取汉字后又拼成汉字的
先根据默认或指定的编码方式把文字编码为字节数组,再以相同的编码方式把字节数组解码为汉字,如果编码和解码的方式不一致,就会出现乱码
java中怎么从byte字节流转换为中文
得知道原来的编码,不然就是使用默认的编码名称
String str = new String(bytes);
String str = new String(bytes, "gbk");
Java 明明是字节流为什么能输出汉字???
ANSI的时代已经过去了。
现在几乎稍微高级点的平台貌似都可以流畅处理了吧.
我乱说的。
你把int i=0;
换成 更小的看看..
java 的byte数组与汉字输出
String在Java是字符数组,他的字符是使用Unicode字符来构建的。
String s=new String(byteArray);
是把数组byteArray[]的值初始化给了s,所以s是一个把byte类型的数据转化为Unicode字符数组的字符串。
java根据字节生成汉字的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java生成字节码文件、java根据字节生成汉字的信息别忘了在本站进行查找喔。
发布于:2022-12-11,除非注明,否则均为
原创文章,转载请注明出处。