首页 > 编程知识 正文

jsp匹配数据库中文出错,jsp匹配数据库中文出错怎么办

时间:2023-12-26 22:40:32 阅读:322888 作者:SKQG

本文目录一览:

为什么我的JSP程序想数据库存入汉字时会出现乱码?怎么解决啊?

jsp传值到数据库出现乱码,一般有两个原因:

一种是jsp将数据发送给数据库时出现乱码,

一种是数据库拿到数据后进行存储是发生乱码,

出现第一种问题时要去看jsp标签中是否是为utf-8,再者就要看项目编目是否为utf-8右键项目名到preference下可以更改项目编码。

出现第二种问题时,代表数据库编码有问题。右键你用的数据库--数据库属性可以更换成utf-8具体视图如下显示,

在编码过程中要保证项目不出现乱码情况就要在创建项目和数据库时对其编码进行上述规定

JSP数据库使用中文用户名就报错

不支持中文。安装的时候不要安装在中文目录下。代码使用的时候中文要带“”。要使用STRING 类型

你使用了过滤,你查看一下过滤的代码

用jsp连接mysql数据库,出现中文乱码,该怎么解决啊

数据库不是乱码,是你设置的编码问题,你用的是cmd来查看的吧,cmd查看的方式的gbk的,和你的数据库编码不一样,就会显示乱码

嗯,对呀,所以你页面显示没有问题,数据库里面存储的也没有问题,而且是用cmd执行sql语句看到的是乱码问题,没有问题的

如何彻底解决jsp页面中文乱码及数据库乱码

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

(这里有个小技巧:不用卸载Mysql数据,找到安装Mysql数据库目录:D:MySQL Server 5.1bin下的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=userpassword=123456useUnicode=truecharacterEncoding=UTF8

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

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

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

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

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

解决:JSP页面取出数据库中的中文出现乱码

jsp读取数据乱码原因如下:

1、JSP连接数据库语句指定的编码不正确

解决方案:在JSP连接数据库的语句中,带上useUnicode=truecharacterEncoding=UTF-8autoReconnect=true

2、JSP页面没有指定数据提交的编码,就会造成乱码:

解决方案:这种乱码的情况,只需在页面开头加上request.setCharacterEncoding("GBK"); 指定提交的即可。

从jsp页面读取数据库 中文变成问号 mysql

从jsp页面读取数据库操作mysql变成问号是因为编码问题导致。

1.架设服务器安装MYSQL时的会让你选择一种编码,如果这种编码与你的网页不一致,可能就会造成JSP页面乱码.

解决方案:如果安装mysql的编码已不能更改,很多朋友是购买虚拟主机建立网站,无权更改MYSQL的安装编码,这一关我们可以跳过,因为只要后面的步聚正确,一样能解决乱码问题

2.在PHPMYADMIN或mysql-front等系统 创建数据库时会让你选择一种编码,如果这种编码与你的网页不一致,也有可能造成JSP页面乱码.

解决方案:修改数据库编码,如果是数据库编码不正确: 可以在phpmyadmin 执行如下命令: ALTER DATABASE `test` DEFAULT CHARACTER SET utf8 COLLATE utf8_bin 。这个命令就是将test数据库的编码设为utf8

3.创建表时会让你选择一种编码,如果这种编码与你的网页编码不一致,也可能造成JSP页面乱码

解决方案:修改表的编码:

ALTER TABLE `category` DEFAULT CHARACTER SET utf8 COLLATE utf8_bin

这个命令就是将一个表category的编码改为utf8

4.创建表时添加字段是可以选择编码的,如果这种编码与你的网页编码不一致,也可能造成JSP页面乱码

解决方案:修改字段的编码:

ALTER TABLE `test` CHANGE `dd` `dd` VARCHAR( 45 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL

这个命令就是将test表中 dd的字段编码改为utf8

5.用户提交JSP页面的编码与显示数据的JSP页面编码不一致,就肯定会造成JSP页面乱码.

解决方案:如果是这种情况容易解决,只需检查一下页面,修改源文件的charset即可。如用户输入资料的JSP页面是big5码, 显示用户输入的JSP页面却是gb2312,这种100%会造成JSP页面乱码

6.字符集不正确

解决方案:要注意:

1.平时你在某些网站看到的文字可能有几种编码, 如你看到一个繁体字,它有可能是big5编码,也有 可能是utf-8编码的,更有可能是gb码的,没错,也就是说有简体编码的繁体字,也有繁体编码的简体字,一定要了解这一点.

2.如果你是做一个简体编码的网页,编码定为GB2312,如果有香港和台湾地区的访客提交繁体的信息,就可能会造成乱码,解决方法就是(A)将网站编码设为utf-8,这样可以兼容世界上所有字符, (B)如果网站已经运作了好久,已有很多旧数据,不能再更改简体中文的设定,那么建议将页面的编码设为GBK,GBK与GB2312的区别就在于:GBK能比GB2312显示更多的字符,要显示简体码的繁体字,就只能用GBK

7.JSP连接MYSQL数据库语句指定的编码不正确

解决方案:在JSP连接数据库的语句中,带上

useUnicode=truecharacterEncoding=UTF-8autoReconnect=true,

但是千万不要犯和我同样的错误哦。

8.JSP页面没有指定数据提交的编码,就会造成乱码:

解决方案:这种乱码的情况,只需在页面开头加上request.setCharacterEncoding("GBK"); 指定提交的即可。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。