jsp (struts) 连接数据库,中文无法显示
本人初学者,刚做了一个struts小程序。(先不考虑国际化)功能:一个页面,页面上的一项内容可以编辑(同时显示数据库中最后一次编辑的内容),提交后将这内容存入数据库MyS...
本人初学者,刚做了一个struts小程序。 (先不考虑国际化)
功能:一个页面,页面上的一项内容可以编辑(同时显示数据库中最后一次编辑的内容),提交后将这内容存入数据库MySQL。
PS:其实就类似BBS,博客等上面的编辑功能。
现在问题是:逻辑功能正常,但中文显示不出来,要么是"????",要么是乱码。
涉及字符集的文件(我估计)应该是:index.jsp
form提交action的处理过程
DB连接池Bean: ConnectionPool(连接字符串的写法)
MySQL的设置
我想问:我要怎么改才行呢?
我以上提到的几处,究竟哪些需要改动呢? 展开
功能:一个页面,页面上的一项内容可以编辑(同时显示数据库中最后一次编辑的内容),提交后将这内容存入数据库MySQL。
PS:其实就类似BBS,博客等上面的编辑功能。
现在问题是:逻辑功能正常,但中文显示不出来,要么是"????",要么是乱码。
涉及字符集的文件(我估计)应该是:index.jsp
form提交action的处理过程
DB连接池Bean: ConnectionPool(连接字符串的写法)
MySQL的设置
我想问:我要怎么改才行呢?
我以上提到的几处,究竟哪些需要改动呢? 展开
2个回答
展开全部
首先,查看数据库中是否也是乱码,若是,请找到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,设置页面编码,编写过滤器
改为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,设置页面编码,编写过滤器
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询