我在DAO里用preparedstatmemt 查询表时,读出来的char类型的中文数据显示???,但是另一张表的char类型的中文数据显示就是正常的,oracle字符集是中文的,用powerbuilder读取的话就是正常的,是怎么一回事啊?
解决方案 »
- google地图纠偏方法
- 一个问卷调查页面,全是单选框,怎样将投票结果显示在页面上
- 无限分类JAVA方法如何用递归删除数据库中的数据
- eclipse导入项目,java文件中文乱码
- 一个问题求助(6:00 前结贴)
- 老问题,请教一个中文显示的问题?
- 哪里有jsp + access程序的源代码可以下载? (立即马上一会儿就给分)
- 从一个JSP跳到一个ACTION, 怎么能在ACTION里找出前JSP的URL? 请指教!
- tomcat包的问题!
- 上传图片,空指针错误,请高手看一下
- [虚心请教] 大家能谈谈自己的java web学习过程吗 我现在学的很痛苦
- java 新手问题 非常基础,请高手多多指教
<filter>
<filter-name>encoding</filter-name>
<filter-class>
filter.FilterEncoding
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>gbk</param-value>
</init-param>
</filter>package filter;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 FilterEncoding implements Filter
{
protected String encoding; // 接收字符编码
protected boolean ignore; // 是否忽略大小写
protected FilterConfig filterConfig; // 初始化配置 public void init(FilterConfig filterConfig) throws ServletException
{
// 从web.xml文件中读取encoding的值
encoding = filterConfig.getInitParameter("encoding");
// 从web.xml文件中读取ignore的值
String value = filterConfig.getInitParameter("ignore");
// 以下三种情况均为忽略大小写
if(value == null)
{
ignore = true;
}
else if(value.equalsIgnoreCase("yes"))
{
ignore = true;
}
else if(value.equalsIgnoreCase("true"))
{
ignore = true;
}
}
// doFilter方法
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException
{
if(ignore || request.getCharacterEncoding() == null)
{
// 如果为空先从web.xml中得到
String encoding = selectEncoding(request);
if(encoding != null)
{
// 设置字符集编码
request.setCharacterEncoding(encoding);
}
}
// 继续执行
chain.doFilter(request, response);
}
// 得到字符编码
private String selectEncoding(ServletRequest request)
{
return encoding;
}
public void destroy()
{
}
}
如果是url的get提交参数带中文的
可以改下面这个文件,加入一个URIEncoding="GBK"
X:\Tomcat 5.5\conf\Server.xml
<Connector
port="8080"
redirectPort="8443"
minSpareThreads="25"
connectionTimeout="30"
maxThreads="150"
maxSpareThreads="75"
URIEncoding="GBK"> jsp头文件<%@ page contentType="text/html;charset=gbk"%> //此处的charset的值要和web.xml里的 <param-value></param-value>值一样但个类的乱码可以这样来解决:tempStr = new String(str.getBytes("iso-8859-1"),"gb2312");
<filter-mapping>
<filter-name>encoding</filter>
<url-pattern>你要过滤的action</url-pattern>
<filter-mapping>