解决jsp文件乱码方法
程序员文章站
2022-05-18 14:34:21
近来在调试jsp文件问题时,中文乱码现象经常遇到,现将处理方法总结一下,供大家参考:1、jsp文件页面显示乱码,这种情况比较好处理,在页面的page指令加上如下一项就ok了:<%@ page...
近来在调试jsp文件问题时,中文乱码现象经常遇到,现将处理方法总结一下,供大家参考:
1、jsp文件页面显示乱码,这种情况比较好处理,在页面的page指令加上如下一项就ok了:
<%@ page contenttype="text/html; charset=gb2312"%>
2、jsp页面采用表单提交时,提交的数据中含有中文,这时我们获取表单数据后,展示到其它页面时也会出现乱码,解决方案是在提交处理的servlet里接收数据时,先加上如下一行代码:
request.setcharacterencoding("gb2312");
这是其中的一种作法,当页面较少时还好,如果页面较多,我每添加新的页面就要加上这句话,所以可以采用过滤器来解决,具体解决步骤如下:
首先写一个过滤器类,代码如下:
package demo;
import java.io.ioexception;
import javax.servlet.filter;
import javax.servlet.filterchain;
import javax.servlet.filterconfig;
import javax.servlet.servletexception;
import javax.servlet.servletrequest;
import javax.servlet.servletresponse;
public class setcharacterencodingfilter implements filter {
public void destroy() {
}
public void dofilter(servletrequest request, servletresponse response,
filterchain chain)throws ioexception, servletexception {
request.setcharacterencoding("gbk");
// 传递控制到下一个过滤器
chain.dofilter(request, response);
}
public void init(filterconfig filterconfig) throws servletexception {
}
}
然后在web.xml文件中添加如下代码:
<filter>
<!--为过滤器起个名字-->
<filter-name>set character encoding</filter-name>
<!--过滤器类的包名.类名-->
<filter-class>demo.setcharacterencodingfilter</filter-class>
</filter>
<filter-mapping>
<filter-name>set character encoding</filter-name>
<!--匹配所有的请求-->
<url-pattern>/*</url-pattern>
</filter-mapping>
这样所有的请求都将交由这个过滤器处理下,这样无论我们添加多少个页面都可以放心了,不用总考虑要加那么一句代码了.
3、在存取时发生乱码现象,这种现象比较郁闷,处理起来相对复杂一点.
首先要在数据存入数据库时,进行如下编码的转换:如我们要把含有中文的字符串存入数据库,首先:
string s=request.getparameter("author");
string author=new string(s.getbytes("iso8859_1"),"gb2312");
string s=rs.getstring("author");
string author=new string(s.getbytes("gb2312"),"iso8859_1");
1、jsp文件页面显示乱码,这种情况比较好处理,在页面的page指令加上如下一项就ok了:
<%@ page contenttype="text/html; charset=gb2312"%>
2、jsp页面采用表单提交时,提交的数据中含有中文,这时我们获取表单数据后,展示到其它页面时也会出现乱码,解决方案是在提交处理的servlet里接收数据时,先加上如下一行代码:
request.setcharacterencoding("gb2312");
这是其中的一种作法,当页面较少时还好,如果页面较多,我每添加新的页面就要加上这句话,所以可以采用过滤器来解决,具体解决步骤如下:
首先写一个过滤器类,代码如下:
package demo;
import java.io.ioexception;
import javax.servlet.filter;
import javax.servlet.filterchain;
import javax.servlet.filterconfig;
import javax.servlet.servletexception;
import javax.servlet.servletrequest;
import javax.servlet.servletresponse;
public class setcharacterencodingfilter implements filter {
public void destroy() {
}
public void dofilter(servletrequest request, servletresponse response,
filterchain chain)throws ioexception, servletexception {
request.setcharacterencoding("gbk");
// 传递控制到下一个过滤器
chain.dofilter(request, response);
}
public void init(filterconfig filterconfig) throws servletexception {
}
}
然后在web.xml文件中添加如下代码:
<filter>
<!--为过滤器起个名字-->
<filter-name>set character encoding</filter-name>
<!--过滤器类的包名.类名-->
<filter-class>demo.setcharacterencodingfilter</filter-class>
</filter>
<filter-mapping>
<filter-name>set character encoding</filter-name>
<!--匹配所有的请求-->
<url-pattern>/*</url-pattern>
</filter-mapping>
这样所有的请求都将交由这个过滤器处理下,这样无论我们添加多少个页面都可以放心了,不用总考虑要加那么一句代码了.
3、在存取时发生乱码现象,这种现象比较郁闷,处理起来相对复杂一点.
首先要在数据存入数据库时,进行如下编码的转换:如我们要把含有中文的字符串存入数据库,首先:
string s=request.getparameter("author");
string author=new string(s.getbytes("iso8859_1"),"gb2312");
string s=rs.getstring("author");
string author=new string(s.getbytes("gb2312"),"iso8859_1");
上一篇: 全文本检索的应用(3)
推荐阅读