表单数据提交后,数据库记录显示为问号的解决

最近用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” URIEncoding=”UTF-8”/>

你可能感兴趣的:(javaweb)