jsp (struts) 连接数据库,中文无法显示

本人初学者,刚做了一个struts小程序。(先不考虑国际化)功能:一个页面,页面上的一项内容可以编辑(同时显示数据库中最后一次编辑的内容),提交后将这内容存入数据库MyS... 本人初学者,刚做了一个struts小程序。 (先不考虑国际化)

功能:一个页面,页面上的一项内容可以编辑(同时显示数据库中最后一次编辑的内容),提交后将这内容存入数据库MySQL。
PS:其实就类似BBS,博客等上面的编辑功能。

现在问题是:逻辑功能正常,但中文显示不出来,要么是"????",要么是乱码。

涉及字符集的文件(我估计)应该是:index.jsp
form提交action的处理过程
DB连接池Bean: ConnectionPool(连接字符串的写法)
MySQL的设置

我想问:我要怎么改才行呢?
我以上提到的几处,究竟哪些需要改动呢?
展开
 我来答
百度网友72b1807
2008-11-27 · TA获得超过301个赞
知道答主
回答量:49
采纳率:0%
帮助的人:0
展开全部
首先,查看数据库中是否也是乱码,若是,请找到mysql的根目录下有个my.ini文件,修改两处default-character-set=latin1 将latin
改为gb2312(注意两处),修改后重启mysql,还要删掉以前的数据库 重新建库,mysql的乱码就解决啦

第二,解决页面的乱码,通常将页面设置为utf-8或GB2312

第三,解决request的乱码,编写过滤器类
public class EncodingFilter implements Filter {
private String charset = null;
public void destroy() {
// TODO Auto-generated method stub

}

public void doFilter(ServletRequest req, ServletResponse resp,
FilterChain chain) throws IOException, ServletException {
req.setCharacterEncoding(this.charset);
chain.doFilter(req, resp);

}

public void init(FilterConfig arg0) throws ServletException {
this.charset = arg0.getInitParameter("charset");

}

}
然后在web.xml文件中配置过滤器:
<!-- 编码过滤器 -->
<filter>
<filter-name>encoding</filter-name>
<filter-class>cn.lh.filter.EncodingFilter</filter-class>
<init-param>
<param-name>charset</param-name>
<param-value>gb2312</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
请把<filter-class>cn.lh.filter.EncodingFilter</filter-class>
包名改为你的包名
重启 服务器,就不会上述的问题啦

注意一下几点:修改mysql的my.ini,设置页面编码,编写过滤器
皇帝爱妃子
2008-11-26 · TA获得超过123个赞
知道答主
回答量:169
采纳率:0%
帮助的人:0
展开全部
把所有的页面的字符改成gb2312的试试 你那不是数据连接的错误 是字符集不统一的问题
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式