解决JSP开发中Web程序显示中文三种方法
程序员文章站
2023-12-04 11:28:28
方法一:最简单也是用的最多的方法 <%@ page language="java" pageencoding="gbk" %> 或者<%@ page content...
方法一:最简单也是用的最多的方法
<%@ page language="java" pageencoding="gbk" %>
或者<%@ page contenttype="text/html;charset=gbk";>这里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。
这个方法用于jsp页面中的中文显示。
方法二:使用过滤器
过滤器使用主要针对表单提交,插入数据库的数据都是?号。这也是应为tomcat不按request所指定的编码进行编码,还是自作主张的采用默认编码方式iso-8859-1编码。
编写一个setcharacterencodingfilter类。
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 {
protected string encoding = null;
protected filterconfig filterconfig = null;
protected boolean ignore = true;
public void init(filterconfig filterconfig) throws servletexception {
this.filterconfig=filterconfig;
this.encoding=filterconfig.getinitparameter("encoding");
string value=filterconfig.getinitparameter("ignore");
if(value==null)
this.ignore=true;
else if(value.equalsignorecase("true"))
this.ignore=true;
else
this.ignore=false;
}
public void dofilter(
servletrequest request, servletresponse response, filterchain chain)
throws ioexception, servletexception {
// todo 自动生成方法存根
if (ignore (request.getcharacterencoding() == null)) {
string encoding = selectencoding(request);
if (encoding != null)
request.setcharacterencoding(encoding);
}
chain.dofilter(request, response);
}
public void destroy() {
// todo 自动生成方法存根
this.encoding = null;
this.filterconfig = null;
}
protected string selectencoding(servletrequest request) {
return (this.encoding);
}
}
然后再web.xml加上
<!-- set character encoding-->
<filter>
<filter-name>set character encoding</filter-name>
<filter-class>com.struts.common.setcharacterencodingfilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>set character encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- set character encoding-->
使用过滤器的好处很多,特别是项目之中。
而且在使用国际化时就更有用了,只要在页面指定 <%@ page language="java" pageencoding="utf-8" %>,服务器就会根据本地locale来显示正确的字符集。
所以我特别推荐使用过滤器。
方法三:修改tomcat的server.xml文件中uriencoding
<connector debug="0" acceptcount="100" connectiontimeout="20000" disableuploadtimeout="true"
port="80" redirectport="8443" enablelookups="false" minsparethreads="25" maxsparethreads="75"
maxthreads="150" maxpostsize="0" uriencoding="gbk" >
</connector>
这个方法主要针对从url中获取字符串的问题。
在tomcat5.0及以上版本,post和get方法在处理编码时有所不同。如果你在url中获取中文就会出现?号。但在tomcat4.1版本没有问题,因为tomcat4.1的post和get方法在处理编码时是一样的。
<%@ page language="java" pageencoding="gbk" %>
或者<%@ page contenttype="text/html;charset=gbk";>这里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。
这个方法用于jsp页面中的中文显示。
方法二:使用过滤器
过滤器使用主要针对表单提交,插入数据库的数据都是?号。这也是应为tomcat不按request所指定的编码进行编码,还是自作主张的采用默认编码方式iso-8859-1编码。
编写一个setcharacterencodingfilter类。
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 {
protected string encoding = null;
protected filterconfig filterconfig = null;
protected boolean ignore = true;
public void init(filterconfig filterconfig) throws servletexception {
this.filterconfig=filterconfig;
this.encoding=filterconfig.getinitparameter("encoding");
string value=filterconfig.getinitparameter("ignore");
if(value==null)
this.ignore=true;
else if(value.equalsignorecase("true"))
this.ignore=true;
else
this.ignore=false;
}
public void dofilter(
servletrequest request, servletresponse response, filterchain chain)
throws ioexception, servletexception {
// todo 自动生成方法存根
if (ignore (request.getcharacterencoding() == null)) {
string encoding = selectencoding(request);
if (encoding != null)
request.setcharacterencoding(encoding);
}
chain.dofilter(request, response);
}
public void destroy() {
// todo 自动生成方法存根
this.encoding = null;
this.filterconfig = null;
}
protected string selectencoding(servletrequest request) {
return (this.encoding);
}
}
然后再web.xml加上
<!-- set character encoding-->
<filter>
<filter-name>set character encoding</filter-name>
<filter-class>com.struts.common.setcharacterencodingfilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>set character encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- set character encoding-->
使用过滤器的好处很多,特别是项目之中。
而且在使用国际化时就更有用了,只要在页面指定 <%@ page language="java" pageencoding="utf-8" %>,服务器就会根据本地locale来显示正确的字符集。
所以我特别推荐使用过滤器。
方法三:修改tomcat的server.xml文件中uriencoding
<connector debug="0" acceptcount="100" connectiontimeout="20000" disableuploadtimeout="true"
port="80" redirectport="8443" enablelookups="false" minsparethreads="25" maxsparethreads="75"
maxthreads="150" maxpostsize="0" uriencoding="gbk" >
</connector>
这个方法主要针对从url中获取字符串的问题。
在tomcat5.0及以上版本,post和get方法在处理编码时有所不同。如果你在url中获取中文就会出现?号。但在tomcat4.1版本没有问题,因为tomcat4.1的post和get方法在处理编码时是一样的。