关于new String(str.getBytes("ISO-8859-1"),"GBK")
2015-04-16 15:42
459 查看
回复:
这种 1+1=?的问题没有一个正确答案,竟然还被推荐 ,看来版主脑子真的有问题了。
除了UTF-16,其它字符集定义时都重复。
比如汉字“我”,假设它的值是22530(只是假设,具体多少我没查)
而日文的“マ”的值也可能是22530(也是假设)或韩文的“찾”
在网络上传输是不能以高字节传输,因为网络底层最后只认无符号char,相当于java中的byte,所以
22530这个int要转换为字节数组,
byte[0] = (22530 >> 8)&0xFF;
byte[1] = 22530 &0xFF;
具体多少我没算,假设是byte[125,231]
这样的字节传到服务端到是表示汉字“我”还是日文的“マ”还是其它狗屁?
一般通讯协议中会告诉对字符集,比如HTTP在请求时告诉服务端:
ContentType="xxxxxxxxxx";charset="GKB";
这时服务端就知道现在接收到的[125,231]是GKB的“我”而不是其它文字。
上面是标准的通信过程。但如果有些水平很差的程序员在提交请求时没有通知服务端字符集,那服务端就没办法了。
只好按最常用的字符集来猜一个默认的。
这还不错,最要命的是写服务器的程序员水平和见识很差时,就要命了。就象写老版本的TOMCAT的程序员,他自己生在西方,以为全世界所有人都用的是26个字母加一些符号,所以他不管客户端提交什么都按ISO-8859-1来算,结果可想而知。
没办法,谁让我们用GBK的人不会写tomcat呢,只好先把让那个差劲的程序员错误生成的String用ISO-8859-1还原成
[125,231],再重新用GKB生成String.
这种 1+1=?的问题没有一个正确答案,竟然还被推荐 ,看来版主脑子真的有问题了。
除了UTF-16,其它字符集定义时都重复。
比如汉字“我”,假设它的值是22530(只是假设,具体多少我没查)
而日文的“マ”的值也可能是22530(也是假设)或韩文的“찾”
在网络上传输是不能以高字节传输,因为网络底层最后只认无符号char,相当于java中的byte,所以
22530这个int要转换为字节数组,
byte[0] = (22530 >> 8)&0xFF;
byte[1] = 22530 &0xFF;
具体多少我没算,假设是byte[125,231]
这样的字节传到服务端到是表示汉字“我”还是日文的“マ”还是其它狗屁?
一般通讯协议中会告诉对字符集,比如HTTP在请求时告诉服务端:
ContentType="xxxxxxxxxx";charset="GKB";
这时服务端就知道现在接收到的[125,231]是GKB的“我”而不是其它文字。
上面是标准的通信过程。但如果有些水平很差的程序员在提交请求时没有通知服务端字符集,那服务端就没办法了。
只好按最常用的字符集来猜一个默认的。
这还不错,最要命的是写服务器的程序员水平和见识很差时,就要命了。就象写老版本的TOMCAT的程序员,他自己生在西方,以为全世界所有人都用的是26个字母加一些符号,所以他不管客户端提交什么都按ISO-8859-1来算,结果可想而知。
没办法,谁让我们用GBK的人不会写tomcat呢,只好先把让那个差劲的程序员错误生成的String用ISO-8859-1还原成
[125,231],再重新用GKB生成String.
相关文章推荐
- new String(str.getBytes("ISO-8859-1"),"GBK")是怎么样一种机制
- 在JSP中,使用get提交方式出现乱码时,为什么要使用new String(s.getBytes("iso-8859-1"),"utf-8");?
- jsp页面中的汉字问题和表单提交汉字问题(***.getBytes("ISO-8859-1")行报错)
- 使用 getBytes("iso-8859-1"),"gb2312" 方法仍出现乱码的解决方法
- page = new String(request.getQueryString().getBytes("ISO-8859-1"),"GBK");解决前台传后台乱码问题
- new String(request.getParameter("newdefrayItem").getBytes("iso-8859-1"),"GBK")
- values[i] = new String(values[i].getBytes("ISO-8859-1"),"utf-8")中文乱码
- 关于保存*.js是出现some character can not mapped using "iso-8859-1" 的问题解决见解
- 分享 返回分享首页» 分享 new String(getBytes(ISO-8859-1),GBK)解决中文乱码问题分析
- new String(str.getBytes("8859-1"),"gb2312")
- new String(getBytes(ISO-8859-1),GBK)解决中文乱码问题分析
- new String(str.getBytes("iso8859-1"), "UTF-8");
- 用MyEciplse时 some character can not mapped using "iso-8859-1" character encoding 解决
- some character can not mapped using "iso-8859-1" character encoding
- 用 MyEciplse时 some character can not mapped using "iso-8859-1" character encoding 解决
- 用MyEciplse时 some character can not mapped using "iso-8859-1" character encoding 解决
- 用MyEclipse写jsp时出现some characters acnnot be mapped using "ISO-8859-1"错误
- new String(getBytes(ISO-8859-1),GBK)解决中文乱码问题分析
- some characters cannot be mapped using"ISO-8859-1'/ GBK MYeclipse
- 用MyEciplse时 some character can not mapped using "iso-8859-1" character encoding 解决