java連接mysql數(shù)據(jù)庫(kù)亂碼的解決方法
更新時(shí)間:2013年05月19日 20:41:01 作者:
這篇文章主要介紹通過(guò)java連接mysql數(shù)據(jù)庫(kù)的時(shí)候,頁(yè)面出現(xiàn)亂碼,這里簡(jiǎn)單分享下解決方法, 需要的朋友可以參考下
解決方法一:
mysql安裝時(shí)候的編碼,
看下my.ini,有無(wú)
[mysql]
default-character-set=utf8
[client]
default-character-set=utf8
[mysqld]
default-character-set=utf8創(chuàng)建表的時(shí)候設(shè)置:
DROP TABLE IF EXISTS `Company`;
CREATE TABLE IF NOT EXISTS `Company`
(
`Cname` VARCHAR(10) NOT NULL,
`Caddr` VARCHAR(100),
`Ctel` VARCHAR(16)
)ENGINE=InnoDB DEFAULT CHARSET=UTF8;
jsp標(biāo)頭:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>不行的話就嘗試:
contentType="text/html;charset=gb2312"
解決方法二:
連接mysql時(shí)(無(wú)論在從mysql讀還是取數(shù)據(jù)的情況),指定使用的編碼方式為utf-8,具體代碼如下
//裝載mysql-jdbc驅(qū)動(dòng)
Class.forName("com.mysql.jdbc.Driver").newInstance();
//連接數(shù)據(jù)庫(kù)
Connection sqlCon = DriverManager.getConnection( "jdbc:mysql://localhost:3306/test?user=root&password=1&useUnicode=true&characterEncoding=utf-8" );
解決方法三:
如果方法一不行那么在方法一的基礎(chǔ)上對(duì)讀入的字符串進(jìn)行強(qiáng)制編碼方式轉(zhuǎn)換。
String name = request.getParameter("name");
name= new String(name.getBytes("ISO-8859-1"),"utf-8");
或者:
String name =new String( rst.getString("name").getBytes("ISO-8859-1"),"utf-8"));
解決方法四:
這個(gè)方法在有些文章里是首推的,我首先也是試了這個(gè)方法,但是好像不行。這里還是說(shuō)一下,不知是不是我操作錯(cuò)誤。還是先貼原文吧:
"如果數(shù)據(jù)庫(kù)中有中文的話而mysql默認(rèn)的語(yǔ)言不是中文時(shí)要在配置文件C:winntmy.ini 中的 [mysqld] 里添加一行:
default-character-set=utf-8
然后重起mysql
方法五:在tomca或者web項(xiàng)目下的web.xml里面更改:
<filter>
<filter-name>UTFEncoding</filter-name>
<filter-class>com.founder.chenph.Util.EncodingFilter_UTF8
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>UTFEncoding</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>UTFEncoding</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
mysql安裝時(shí)候的編碼,
看下my.ini,有無(wú)
復(fù)制代碼 代碼如下:
[mysql]
default-character-set=utf8
[client]
default-character-set=utf8
[mysqld]
default-character-set=utf8創(chuàng)建表的時(shí)候設(shè)置:
DROP TABLE IF EXISTS `Company`;
CREATE TABLE IF NOT EXISTS `Company`
(
`Cname` VARCHAR(10) NOT NULL,
`Caddr` VARCHAR(100),
`Ctel` VARCHAR(16)
)ENGINE=InnoDB DEFAULT CHARSET=UTF8;
jsp標(biāo)頭:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>不行的話就嘗試:
contentType="text/html;charset=gb2312"
解決方法二:
連接mysql時(shí)(無(wú)論在從mysql讀還是取數(shù)據(jù)的情況),指定使用的編碼方式為utf-8,具體代碼如下
//裝載mysql-jdbc驅(qū)動(dòng)
Class.forName("com.mysql.jdbc.Driver").newInstance();
//連接數(shù)據(jù)庫(kù)
Connection sqlCon = DriverManager.getConnection( "jdbc:mysql://localhost:3306/test?user=root&password=1&useUnicode=true&characterEncoding=utf-8" );
解決方法三:
如果方法一不行那么在方法一的基礎(chǔ)上對(duì)讀入的字符串進(jìn)行強(qiáng)制編碼方式轉(zhuǎn)換。
String name = request.getParameter("name");
name= new String(name.getBytes("ISO-8859-1"),"utf-8");
或者:
String name =new String( rst.getString("name").getBytes("ISO-8859-1"),"utf-8"));
解決方法四:
這個(gè)方法在有些文章里是首推的,我首先也是試了這個(gè)方法,但是好像不行。這里還是說(shuō)一下,不知是不是我操作錯(cuò)誤。還是先貼原文吧:
"如果數(shù)據(jù)庫(kù)中有中文的話而mysql默認(rèn)的語(yǔ)言不是中文時(shí)要在配置文件C:winntmy.ini 中的 [mysqld] 里添加一行:
default-character-set=utf-8
然后重起mysql
方法五:在tomca或者web項(xiàng)目下的web.xml里面更改:
復(fù)制代碼 代碼如下:
<filter>
<filter-name>UTFEncoding</filter-name>
<filter-class>com.founder.chenph.Util.EncodingFilter_UTF8
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>UTFEncoding</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>UTFEncoding</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
您可能感興趣的文章:
- Java連接MySql的詳細(xì)介紹
- Java連接MYSQL數(shù)據(jù)庫(kù)的實(shí)現(xiàn)步驟
- java連接mysql數(shù)據(jù)庫(kù)詳細(xì)步驟解析
- java連接MySQl數(shù)據(jù)庫(kù)實(shí)例代碼
- java連接Mysql數(shù)據(jù)庫(kù)的工具類
- java連接MySQL數(shù)據(jù)庫(kù)實(shí)現(xiàn)代碼
- JavaWeb連接數(shù)據(jù)庫(kù)MySQL的操作技巧
- javaweb中mysql數(shù)據(jù)庫(kù)連接步驟方法及其實(shí)例
- java連接mysql數(shù)據(jù)庫(kù)的方法
- Java+MySQL前后端連接新手小白教程
相關(guān)文章
SpringCloud OpenFeign超時(shí)控制示例詳解
在Spring Cloud中使用OpenFeign時(shí),可以通過(guò)配置來(lái)控制請(qǐng)求的超時(shí)時(shí)間,這篇文章主要介紹了SpringCloud OpenFeign超時(shí)控制,需要的朋友可以參考下2024-05-05
Java實(shí)現(xiàn)List集合手動(dòng)分頁(yè)的方法
在工作中難免會(huì)遇到,將組裝的集合數(shù)據(jù)進(jìn)行分頁(yè)處理,本文主要介紹了Java實(shí)現(xiàn)List集合手動(dòng)分頁(yè)的方法,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03
用java實(shí)現(xiàn)跳動(dòng)的小球示例代碼
這篇文章主要介紹了用java實(shí)現(xiàn)跳動(dòng)的小球,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
基于struts2和hibernate實(shí)現(xiàn)登錄和注冊(cè)功能
這篇文章主要為大家詳細(xì)介紹了基于struts2和hibernate實(shí)現(xiàn)登錄和注冊(cè)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
Springboot如何實(shí)現(xiàn)Web系統(tǒng)License授權(quán)認(rèn)證
這篇文章主要介紹了Springboot如何實(shí)現(xiàn)Web系統(tǒng)License授權(quán)認(rèn)證,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
SSH框架網(wǎng)上商城項(xiàng)目第9戰(zhàn)之添加和更新商品類別功能實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了SSH框架網(wǎng)上商城項(xiàng)目第9戰(zhàn)之添加和更新商品類別功能實(shí)現(xiàn),感興趣的小伙伴們可以參考一下2016-06-06

