<%out.print(new String(request.getParameter("type").getBytes("8859_1"),"gb2312")+"</br>");%>
<a href="test2.jsp?type=<%
out.print(java.net.URLEncoder.encode("供应"));
%>">aaaaaaaa</a>
<a href="test2.jsp?type=<%
out.print(java.net.URLEncoder.encode("供应"));
%>">aaaaaaaa</a>
解决方案 »
- 关于CXF获取IP的方法
- 菜鸟提问 谢! request.getContentPath() 是获得 tomcat server。xml里边<Context path="aa" />中path 指定的值吗
- jsp页面中如何显示指定IP的硬盘文件?
- java访问xml的问题~~?
- [急]关于byte与byte间的异或处理
- 请各位帮帮初学者,给我点信心,拜托
- 各位大侠 请问谁能告诉我 jspsmart的下载地址
- 为什么在sun得网站上找不到BDK,也找不到bean builder
- jdk1.4是不是和sql server 2000 jdbc不兼容?
- 有哪几种方法做分页比较好的?
- 怎样使用javascript做的动态菜单不被主页面框架所掩盖
- 怎么在程序中得到另一个网站的查询结果?
这里%E7%8E%8B就是url encoding后的王的utf编码
文章类别:jsp加入时间:2003-7-22 人气指数:3700
在基于JAVA的编程中,经常会碰到汉字的处里及显示的问题,比如一大堆乱码或问号。
这是因为JAVA中默认的编码方式是UNICODE,而中国人通常使用的文件和DB都是基于GB2312或者BIG5等编码,故会出现此问题。以前我也经常为这个问题而苦恼,后来经查了些资料,终于解决了,我知道一定有很多朋友也会碰到这个问题,所以特就总结了一下,来拿出来让大家一起分享了。
1、在网页中输出中文。
JAVA在网络传输中使用的编码是"ISO-8859-1",故在输出时需要进行转化,如:
String str="中文";
str=new String(str.getBytes("GB2312"),"8859_1");
但如果在编译程序时,使用的编码是“GB2312”,且在中文平台上运行此程序,不会出现此问题,一定要注意。
2、从参数中读取中文
这正好与在网页中输出相反如:
str=new String(str.getBytes("8859_1"),"GB2312");
3、操作DB中的中文问题
一个较简单的方法是:在“控制面扳”中,把“区域”设置为“英语(美国)”。如果还会出现乱码,还可进行如下设置:
取中文时:str=new String(str.getBytes("GB2312"));
向DB中输入中文:str=new String(str.getBytes("ISO-8859-1"));4、在JSP中的中文解决:在“控制面扳”中,把“区域”设置为“英语(美国)”.
在JSP页面中加入:
如果还不行正常显示,则还要进行下面的转换:
如:name=new String(name.getBytes("ISO-8859-1"),"GBK");
就不会出现中文问题了。
我不是说会出让码
而是URL如何编码问题
可以利用URLDecoder之类,但是编译器会告诉我们建议不要使用该类型。
<a href="test2.jsp?type=<%
out.print(java.net.URLEncoder.encode("供应"));
%>">aaaaaaaa</a>代码都给出了还要这样讨论的啊