表单数据提交后,数据库记录显示为问号的解决
2016-05-26 20:49
274 查看
最近用SSH2做一个javaweb项目,可是遇到了乱码问题。明明jsp页面、mysql、tomcat全部设置为utf-8编码方式。在提交表单到数据库后还是变成问号,经过几番研究,终于解决了问题。
解决方法如下:连接数据库的时候需要指定编码方式,如下所示:jdbc.driver = com.mysql.jdbc.Driver
jdbc.url = jdbc:mysql:///shop?useUnicode=true&characterEncoding=UTF-8
jdbc.user = root
jdbc.password =admin
下边我再提供一些解决乱码的方法,希望能帮到大家:
(乱码问题的解决不在于用什么编码方式,而在于你数据所经过的所有地方都采用同样的编码方式,
这里我以utf-8为例)
一、MyEclipse下编码的设定
1、window -> Preferences -> general -> Workspace -> Text file encoding(工作区的编码设定)
选择Other,将编码改变为UTF-8。
2、window -> Preferences -> general -> Content Types(这里是设置不同文件的编码,例如Java文件,jsp文件,css文件等不同类型的文件的编码方式)
二、Jsp页面编码解码方式的设定
1、<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
2、<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
三、数据库(如mysql)采用UTF-8编码
ALTER DATABASE `db_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
四、表单方式中文乱码解决方案
1.表单使用Post方式提交后接收到的乱码问题
这个问题是一个常见的问题。这个乱码也是tomcat的内部编码格式iso8859-1在捣乱,也就是说post提交时,如果没有设置提交的编码格式,则会以iso8859-1方式进行提交,接受的Jsp却以utf-8的方式接受。导致乱码。既然这样的原因,下面有几种解决方式,并比较。
(1).接受参数时进行编码转换 String str = new String(request.getParameter("something").getBytes("ISO-8859-1"),"utf-8")
; 这样的话,每一个参数都必须这样进行转码,很麻烦,但确实可以拿到汉字。
(2)在请求页面上开始处,执行请求的编码代码, request.setCharacterEncoding("UTF-8"),把提交内容的字符集设为UTF-8。这样的话,接受此参数的页面就不必在转码了。
(3)为了简单起见,避免重复的写request.setCharacterEncoding("UTF-8"),建议使用过滤器对所有jsp进行编码处理。
2. 表单get提交方式的乱码处理方式。
如果使用get方式提交中文,接受参数的页面也会出现乱码,这个乱码的原因也是tomcat的内部编码格式iso8859-1导致。Tomcat会以get的缺省编码方式iso8859-1对汉字进行编码,编码后追加到url,导致接受页面得到的参数为乱码。
解决办法:
(1)使用上例中的第一种方式,对接受到的字符进行解码,再转码。
(2)在tomcat的conf目录下的server.xml中配置URIEncoding=”UTF-8” <Connector port="8080" maxThreads="150"
minSpareThreads="25" maxSpareThreads="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" useBodyEncodingForURI="true" disableUploadTimeout="true"
URIEncoding=”UTF-8”/>
相关文章推荐
- SQL注入测试平台 SQLol -4.UPDATE注入测试
- 细心很重要---猜猜这个SQL执行的什么意思
- MySQL Workbench不能启动
- JamesMusic浅读--------2,ListViewCardsAdapter和数据库初显
- MYSQL自动备份脚本
- 【数据库】安装和配置Oracle客户端
- SQL注入测试平台 SQLol -3.INSERT注入测试
- 山东环保数据库迁移
- 数据文件的组织形式
- mybatis系列-08-动态sql
- Oracle 对表设置并行度对执行计划的影响
- oracle数据库的常用命令
- mysql dump使用实例
- MySql两三事
- jdbc调用mysql存储过程实现代码带有输入和输出
- mysql的存储引擎如何选择
- Excel 导入到Datatable 中,再使用常规方法写入数据库
- mybatis系列-05-SqlMapConfig.xml详解
- oracle的新建用户表空间等
- Androin学习笔记五十二: SQLiteCursor(示例,出错代码)