JSP页面数据库中的中文出现乱码是怎么回事?

JSP页面数据库中的中文出现乱码是怎么回事?,第1张

首先把你获取的页面的数据用DB的编码方式重新编码一下再存入DB.

如String tstna=request.getParameter("shijuanming")

改成String tstna=request.getParameter("shijuanming")

tstna = new String(tstna.getBytes("ISO-8859-1", "GB2312"))

后面的一个编码方式,如果DB是GB2312,那就是这个,如果不是,改成DB相应的编码方式就行了.

当然,把mysql 和 jsp上编码格式设置一致即可, 一般默认mysql的编码格式是UTF-8, 建议在jsp中也设置为UTF-8, 如果你不想这么做的话要改数据库格式, 也就是说你所有建立的表都要重新建立成GBK编码。

刚开始学习jsp的程序员都会遇到这样一个问题,就是网页上的中文无法显示.总结了以下几条方法。 \x0d\x0a1、在jsp页中加入一条语句: \x0d\x0a中文显示就正常了。 \x0d\x0a\x0d\x0a2、对于从网页中的文本框通过String parameter = request.getParameter(“parameter”)方式获得的字符串,均是8859_1的编码, \x0d\x0a如果想把它显示在网页上就必须得用parameter = new String(parameter.getBytes(“8859_1”),”gb2312”)进行转换,windows和linux这两种系统都是一样的。 \x0d\x0a有一个简单方法,就是在 getParameter() 方法获取参数之前,使用request.setCharacterEncoding("GB2312"),将提交的信息转化为 GB2312 编码。 \x0d\x0a\x0d\x0a3、但是对于将数据写入数据库的问题,采取的方式就不同了: \x0d\x0awindows下,必须要采用该字符串转换再插入数据库,而linux下就不需要,而是直接把8859_1编码的字符插入。 \x0d\x0a如果从数据库中读出的数据,对于windows因为在插入时已经做了转换,所以读出时已经是gb2312的,当把它显示在网页上时,不需要做编码转换,而 linux上的mysql中的数据是8859_1的所以要做编码的转换。 \x0d\x0a\x0d\x0a4、 如果你给某个字符串变量赋予一个中文字符串的值,那么在你取出他时,在网页上的显示是不需要做字符转换的, \x0d\x0a但是如果你要在linux下做字符的比较,则还需要把字符做parameter = new String(parameter.getBytes(“gb2312”),”8859_1”)的转换。 \x0d\x0a\x0d\x0a5、长江电力网站解决中文问题的方法是: \x0d\x0a1)在catalina.sh文件中的相关位置添加下面一行 \x0d\x0a-Dfile.encoding=GBK \ \x0d\x0a2)在每个jsp文件的最前面添加下面两行 \x0d\x0a \x0d\x0a


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10650403.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存