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)后数据库显示正常!请各位高手帮忙
展开
 我来答
百度网友72b1807
2008-11-27 · TA获得超过301个赞
知道答主
回答量:49
采纳率:0%
帮助的人:0
展开全部
好像 你这个问题问了两遍啦
我在另一个里 帮你 解答啦

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后(两处) 一定要删掉以前的数据库 重新建
yanghaoynu
2008-11-27 · TA获得超过625个赞
知道小有建树答主
回答量:311
采纳率:0%
帮助的人:355万
展开全部
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的话最好使用第二中方法
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jichiduo
2008-11-25 · TA获得超过974个赞
知道小有建树答主
回答量:277
采纳率:0%
帮助的人:253万
展开全部
mysql在更改字符集之前建立的表都会是以前字符集的编码
所以你要看看,而且,出现乱码的主要可能还是你的servlet容器配置有问题,如果你用的是tomcat的话,检查一下它的配置是否正确
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
TheStroll
2008-11-20
知道答主
回答量:33
采纳率:0%
帮助的人:20.9万
展开全部
是不是MySQL数据库编码设置了但是数据库里面的表没设置编码啊?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
AI创新工坊
2008-11-23
知道答主
回答量:24
采纳率:0%
帮助的人:15.3万
展开全部
你可以看看你数据库里插入的数据是乱码?如果是就是插入的问题,有可能是jsp数据编码错误,或者就是MySQL编码错误,你一步一步的找嘛,总会找到的!如果数据库的值正常,那么就是显示错误了,在显示的时候也要设置字符编码,你再看看是哪儿错误,错误是一步一步找出来的,一个一个排除就出来了嘛!再有问题给我留言
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式