JSP+Servlet+tomcat6.0+mysql中查询英文正常,但是中文查不出结果也不报错


1、首先要检查tomcat-->conf-->server.xml中字符集要改为一致,比如:UTF-8

2、在servlet的doGet或service中要设置

request.setCharacterEncoding("UTF-8")

3、web.xml中设置servlet的初始化参数

 
 

 <servlet>
    <init-param>
       <param-name>encoding</param-name>
       <param-value>UTF-8</param-value>
    </init-param>
  </servlet>


4、jsp页面需要注意的是

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" %>

 

按照以上四点检查完毕后如果还是不行,就要写过滤器了:

package jspServletConnnectionCommons;

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 CharacterEncodingFilter implements Filter{
 
 private String encode;
 
 //初始化
 @Override
 public void init(FilterConfig filterConfig) throws ServletException {
  encode = filterConfig.getInitParameter("encode");
  
 }
 //执行过滤
 @Override
 public void doFilter(ServletRequest req, ServletResponse res,
   FilterChain filterChain) throws IOException, ServletException {
  req.setCharacterEncoding(encode);
  filterChain.doFilter(req, res);
 }
 //销毁
 @Override
 public void destroy() {
  encode = null;
 }

}

再在web.xml中配置filter如下:
<filter> 
   <filter-name>characterEncodingFilter</filter-name>    
   <filter-class>org.itfuture.examples.web.filter.CharacterEncodingFilter</filter-class>    
   <init-param>       
     <param-name>encode</param-name>       
     <param-value>UTF-8</param-value>    
   </init-param>
   <init-param>          
     <param-name>encoding</param-name>          
     <param-value>UTF-8</param-value>       
   </init-param>
</filter>
<filter-mapping>       
   <filter-name>characterEncodingFilter</filter-name>       
   <url-pattern>/*</url-pattern>  
</filter-mapping>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值