解决JSP开发Web程序中的中文问题

本文介绍了在Web开发中遇到的中文乱码问题及其解决方案,包括设置JSP页面编码、使用过滤器统一字符编码及修改Tomcat配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这段时间经常看到有人问到web开发中怎么中文总是?号。原因其实很简单,因为大家大多用的是tomcat服务器,而tomcat服务器的默认编码为 iso-8859-1(西欧字符)。就是因为iso-8859-1(西欧字符)编码造成了我们经常看到?号。   方法一:最简单也是用的最多的方法。   <%@ 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中获取字符串的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值