jsp+hibernate+mysql乱码
您好请问您一下我做得jsp+hibernate+mysql的项目,先是用gbk的jsp输入数据,然后用gbk的jsp显示数据出现乱码,mysql已经默认成charset=...
您好 请问您一下 我做得jsp+hibernate+mysql的项目,先是用gbk的jsp输入数据,然后用gbk的jsp显示数据出现乱码,mysql已经默认成charset=gbk谢谢您好 请问您一下 我做得jsp+hibernate+mysql的项目,先是用gbk的jsp输入数据,然后用gbk的jsp显示数据出现乱码,mysql已经默认成charset=gbk谢谢
<%page contentType="text/html;charset=gbk"%>
与<%page pageEncoding="gbk"%>有什么区别?谢谢
连数据库是UseUnicode=true&characterEncoding+GBK是什么意思,谢谢
我用数组把要传递到数据库的字符getBates(iso-8859-1)后数据库显示正常!请各位高手帮忙 展开
<%page contentType="text/html;charset=gbk"%>
与<%page pageEncoding="gbk"%>有什么区别?谢谢
连数据库是UseUnicode=true&characterEncoding+GBK是什么意思,谢谢
我用数组把要传递到数据库的字符getBates(iso-8859-1)后数据库显示正常!请各位高手帮忙 展开
展开全部
好像 你这个问题问了两遍啦
我在另一个里 帮你 解答啦
1. 将default-character-set=latin1 将latin
改为gb2312(注意两处),
修改后一定重启mysql,还要删掉以前的数据库 重新建库,mysql就不会出现乱码啦
2.编写过滤器
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>
包名改为你的包名
重启 服务器,就不会乱码啦
注意:修改my.ini后(两处) 一定要删掉以前的数据库 重新建
我在另一个里 帮你 解答啦
1. 将default-character-set=latin1 将latin
改为gb2312(注意两处),
修改后一定重启mysql,还要删掉以前的数据库 重新建库,mysql就不会出现乱码啦
2.编写过滤器
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>
包名改为你的包名
重启 服务器,就不会乱码啦
注意:修改my.ini后(两处) 一定要删掉以前的数据库 重新建
展开全部
1)
request.setCharacterEncoding="GBK";
response.setCharacterEncoding="GBK";
(2)
String tempstr = request.getParameter("pname");
String str = new String(tempstr.getBytes("ISO-8859-1"),"GBK");
然后再进行使用
当然.前提是你要保证数据库字符显示正常
UseUnicode=true&characterEncoding=GBK是说该数据库使用"GBK"这个编码大多时候不需要这样处理,只有在你没有指定数据库字符类型时才需要这样处理
上面两种方式你自行尝试!!如果是你还使用着javaBean的话最好使用第二中方法
request.setCharacterEncoding="GBK";
response.setCharacterEncoding="GBK";
(2)
String tempstr = request.getParameter("pname");
String str = new String(tempstr.getBytes("ISO-8859-1"),"GBK");
然后再进行使用
当然.前提是你要保证数据库字符显示正常
UseUnicode=true&characterEncoding=GBK是说该数据库使用"GBK"这个编码大多时候不需要这样处理,只有在你没有指定数据库字符类型时才需要这样处理
上面两种方式你自行尝试!!如果是你还使用着javaBean的话最好使用第二中方法
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
mysql在更改字符集之前建立的表都会是以前字符集的编码
所以你要看看,而且,出现乱码的主要可能还是你的servlet容器配置有问题,如果你用的是tomcat的话,检查一下它的配置是否正确
所以你要看看,而且,出现乱码的主要可能还是你的servlet容器配置有问题,如果你用的是tomcat的话,检查一下它的配置是否正确
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
是不是MySQL数据库编码设置了但是数据库里面的表没设置编码啊?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你可以看看你数据库里插入的数据是乱码?如果是就是插入的问题,有可能是jsp数据编码错误,或者就是MySQL编码错误,你一步一步的找嘛,总会找到的!如果数据库的值正常,那么就是显示错误了,在显示的时候也要设置字符编码,你再看看是哪儿错误,错误是一步一步找出来的,一个一个排除就出来了嘛!再有问题给我留言
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询