最近开始又转向J2EE的开发。很久没用,重新熟悉。

本地环境ubuntu 12.13,mysql5.x,tomcat7.x,struts2.3.15.x,spring3.1.0,hibernate4.1.x

之前一直连线上服务器上测试数据库,没有发现有中文乱码问题。

现在在本地搭建此环境,使用本地数据库,便于调试,但是发现每次对数据库操作,有中文就会出现????乱码。

那现在一步步排除什么原因引起:

  1. 前端jsp或者html界面:

对于在页面中显示出现乱码,这个问题比较简单,便是检查你的JSP文件里是不是出现了中文要处理,因为JSP默认的编码格式为“ISO-8859-1”,当JSP中出现要处理的中文时,其显示就出现乱码了,这种情况一般出现在手写JSP,或修改时。

<%@ page language="java" contentType="text/html; charset=utf-8"pageEncoding="UTF-8"%>

2、传参数过程中乱码

传递参数出现的乱码,参数的内容为中文。无论是post或者get。

需要关注的位置:

  • tomcat 配置,位置 tomcat->conf->server.xml,加入URIEncoding="utf-8"

<Connector port="8080" protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="8443" URIEncoding="utf-8"/>
  • web.xml中加入过滤器filter

<filter><filter-name>encodingFilter</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param></filter><filter-mapping><filter-name>encodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping>

上面项目中用的spring带的web字符过滤器

  • tomcat 配置,位置 tomcat->conf->web.xml     放开注释的过滤器

<!-- A filter that sets character encoding that is used to decode --><!-- parameters in a POST request --><filter><filter-name>setCharacterEncodingFilter</filter-name><filter-class>org.apache.catalina.filters.SetCharacterEncodingFilter</filter-class><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param><async-supported>true</async-supported></filter>
  • 编写过滤器Filter (这个没用到)

3、后台部分

主要是关注:hibernate和mysql(我项目用的mysql数据库)

  • hibernate注意:

连接mysql,如果用hibernate.cfg.xml加上属性.

<property name="connection.useUnicode">true</property>

<property name="connection.characterEncoding">UTF-8</property>

如果用spring配置文件:

有两种方法,1、直接写到applicationContext.xml中;2、写到database-config.properties中,由applicationContext.xml调用

database-config.properties:

mydata.driverClass=com.mysql.jdbc.Driver
#mydata.url=jdbc:mysql://localhost:3306/sdk?useUnicode=true&characterEncoding=UTF-8
mydata.url=jdbc:mysql://localhost:3306/sdk?useUnicode=true&characterEncoding=UTF-8
mydata.username=root
wshouyouDB.password=xxxx

(我遇到的问题是出现上段代码中)

applicationContext.xml:

<!-- 读取jdbc.properties配置文件 --><beanclass="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="locations"><value>classpath:database-config.properties</value></property></bean><bean id="dataSource" destroy-method="close"class="com.mchange.v2.c3p0.ComboPooledDataSource"><property name="driverClass" value="${mydata.driverClass}" /><property name="jdbcUrl" value="${mydata.url}" /><property name="user" value="${mydata.username}" /><property name="password" value="${mydata.password}" />
  • mysql部分

创建数据库表中,注意:

show create table gamepad_model;看一下创建表的语句

CREATE TABLE `gamepad_model` (`edit_id` varchar(50) NOT NULL,`filedata` text,`gamepad_type` varchar(100) NOT NULL,`pic_url` varchar(255) DEFAULT NULL,`sdk_version` varchar(50) NOT NULL,`update_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,PRIMARY KEY (`edit_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

需要加上: CHARSET=utf8

排除是不是mysql的问题,可以手动插入一条含有中文的数据,看看表中是否有乱码;

insert into gamepad_model(edit_id,filedata,gamepad_type,sdk_version) values('test3_测试','ttt','testtt_你好','1');

如果没有问题,则排除mysql问题

一步一步排除

1、前台,是否有乱码,不是,传递参数层

2、传递参数,到java中,看到传递过来的中文,debug下是否有中文乱码,如果没有,排除之

3、前两步排除后,就应该是后台问题,hibernate或者mysql问题,

4、可以先看上边提到的,手动插入一句有中文内容的语句,看数据库中是否有乱码,如果没有,排除之

5、到这一步,就只剩下hibernate问题了。在上文中,提到注意的地方,检查。

我的问题就在这一步,

mydata.url=jdbc:mysql://localhost:3306/sdk?useUnicode=true&characterEncoding=UTF-8

一般不在xml中,连接数据库需要加上

useUnicode=true&characterEncoding=UTF-8

但是如果在xml中,需要转意一下

mydata.url=jdbc:mysql://localhost:3306/sdk?useUnicode=true &amp; characterEncoding=UTF-8

其他方面没有研究,有的话,请多指教!

  • 相关文章推荐:

  • Tomcat在Linux上使用Native Library

  • apache+3tomcat+jk+memcached集群环境搭建

  • Linux(ubuntu12.04)下搭建Nginx+Tomcat

  • 本文来自:爱好Linux技术网

  • 本文链接:http://www.ahlinux.com/tomcat/9253.html

转载于:https://blog.51cto.com/9626185/1579052

tomcat+SSH中遇到中文乱码的解决方法相关推荐

  1. spring mvc中关于url中传递中文乱码的解决方法

    在传值过程中,也是乱码出现的频繁地.先不说到底是什么场景了,通常常用的方案有如下几个 配置指定的filter <!-- 配置请求过滤器,编码格式设为UTF-8,避免中文乱码--><f ...

  2. 【编程工具】程序中出现中文乱码的解决方法

    很多同学在用别人源码都会碰到这个问题,程序中充斥着大量的中文乱码. 怎么解决这个问题呢,很简单: 在工程的属性下找文本编码方式这一项,然后选择正确的编码方式,一般都是UTF-8,如果不可以的话,可以一 ...

  3. Activiti保存.png 流程图片文件且解决idea中保存图片时显示中文乱码的解决方法

    Activiti保存.png 流程图片文件且解决idea中保存图片时显示中文乱码的解决方法 Eclipse 工具中的操作 流程图片生成的两种方式: 使用 activiti-designer 设计流程图 ...

  4. RStudio控制台(console)中出现少量中文乱码的解决方法

    RStudio控制台(console)中出现少量中文乱码的解决方法 参考文章: (1)RStudio控制台(console)中出现少量中文乱码的解决方法 (2)https://www.cnblogs. ...

  5. java 显示中文_java显示中文乱码的解决方法

    java显示中文乱码的解决方法 发布时间:2020-06-16 11:08:43 来源:亿速云 阅读:97 作者:Leah 这篇文章运用简单易懂的例子给大家介绍java显示中文乱码的解决方法,代码非常 ...

  6. idea控制台中文乱码的解决方法(最后一种亲测有效)

    idea控制台中文乱码的解决方法(三种,亲测有效) 问题情况: IntelliJ IDEA 控制台输出中文乱码部分如图所示: 解决方法: 方法一: 1.打开tomcat配置页面,Edit Config ...

  7. ASP+Access中文乱码的解决方法,ASP中文乱码,asp乱码问题

    确保编码声明正确(例:时尚淘女之家http://www.tao36524.com) 如果您使用的是国外空间,默认是西欧而不是GB2312,你可以通过强制为GD2312的方式! 在数据提取页面的第一行代 ...

  8. linux命令框显示中文乱码_CentOS终端命令行显示中文乱码的解决方法

    这篇文章主要介绍了CentOS终端命令行显示中文乱码的解决方法,以及测试方法和缺少中文字体时的解决方法,需要的朋友可以参考下 安装CentOS的时候选择了中文,结果在终端不能显示中文,都是乱码,解决方 ...

  9. c php乱码,php分割GBK中文乱码的解决方法

    类似如下的字符串(GBK), explode不能得到正确结果: $result = explode("|", "滕华弢|海青"); 究其原因, 对于" ...

最新文章

  1. ASP.NET Web API 使用Swagger生成在线帮助测试文档
  2. 结构体相互嵌套使用的条件?
  3. php优先级,PHP运算优先级——神一般的设定
  4. 长春理工大学第十四届程序设计竞赛(重现赛)F.Successione di Fixoracci
  5. nginx和tomcat整合
  6. etcd-java使用
  7. [蓝桥杯]打水问题、夺宝奇兵、调手表(c++详解)
  8. 实现 RadioButtonList 单选按钮组设置及横向布局
  9. info在python中的意思_为什么我没有在python中收到日志INFO消息?
  10. 哔哩哔哩 Web 首页重构——回首2021
  11. 地球信息科学与技术类毕业论文文献有哪些?
  12. VB编程:数组中删除数组元素-27
  13. python怎么批量下载年报_Python+Wind 批量下载上市公司年报 - Part 1/2
  14. linux下rdesktop用法
  15. webrtc janus服务器部署在公网,coturn转发媒体流
  16. 数字经济下的发展挑战
  17. 一瓶OTC,药店被罚10万,原因是...
  18. C语言源代码系列-管理系统之学生信息管理系统
  19. 三体2:黑暗森林 读后感
  20. ERR_CACHE_MISS

热门文章

  1. linux LVM 系统盘扩容
  2. CentOS-6.9升级到Python-3.5
  3. 如何从零构建实时的个性化推荐系统?
  4. mysql对数据库的备份和还原
  5. php -- 检查是否存在
  6. 影响视频会议效果的因素及案例分析
  7. Winform 系统调优
  8. 记录 Git命令速查表
  9. Excel 单元格不能设置超链接
  10. 使用C#创建SQLite控制台应用程序