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文件中的url后面加入了"..&useUnicode=true&characterEncoding=gbk"

没什么意义。

你插入之前就是乱码了

这句话对get方式提交的参数起作用

String

uname=

new

String(name.getBytes("ISO-8859-1"),"gbk")

如果是post方法提交表单则使用

request.setCharacterEncoding("gbk")进行编码转换

注意不要重复转换!另外请确保你jsp页面的编码格式也是gbk

1、知道自己安装Mysql数据库安装配置时选择了什么编码方式,如果之前安装,现在不太清楚,建议重新安装Mysql数据库,安装配置时选择utf8

(这里有个小技巧:不用卸载Mysql数据,找到安装Mysql数据库目录:D:\MySQL Server 5.1\bin下的MySQLInstanceConfig.exe,双击运行可以进行重新配置安装,并选择utf8编码方式),如图

2、安装成功后,查看编码方式,sql命令如下:

show variables like 'character%'

这里的所有编码方式都要统一为utf8,若某一个不是utf8的编码方式,就要设置为utf8,sql命令如下:set character_set_results=utf8

3、创建数据库并指定数据库的编码方式,sql命令如下:

create database yourDB character set utf8

4、创建数据库表,也要指定其编码方式

5、如果你的Mysql版本是5.0以下,则还需要在hibernate.cfg.xml配置里面url指定数据库访问连接时的编码方式:

如:url=jdbc:mysql://localhost/db?user=user&password=123456&useUnicode=true&characterEncoding=UTF8

如果Mysql版本是5.0以上,这里的url加不加?user=user&password=123456&useUnicode=true&characterEncoding=UTF8 都没关系

6、写一个字符编码的过滤器,编码方式也要保证跟mysql的字符集一致为UTF-8

注意:在web.xml配置该过滤器时,必须把该过滤器的<filter-mapping>放在struts的映射前面,不然起不到过虑作用

7、所有jsp页面指定编码格式,保证跟mysql的字符集一致为UTF-8

注意:页面里面大小写统一,如<%@ page pageEncoding="UTF-8" contentType="text/htmlcharset=UTF-8" %>,不能是pageEncoding="UTF-8",contentType="text/htmlcharset=utf-8",添加数据页面也要跟显示数据页面的编码格式要保持一致,不然的话就会出现添加到数据库中没乱码,从数据库中显示出现乱码的情况


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存