亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決springmvc+mybatis+mysql中文亂碼問題

 更新時(shí)間:2015年09月02日 10:35:18   投稿:hebedich  
這篇文章主要介紹了解決java中springmvc+mybatis+mysql中文亂碼問題的相關(guān)資料,需要的朋友可以參考下

近日使用ajax請(qǐng)求springmvc后臺(tái)查詢mysql數(shù)據(jù)庫,頁面顯示中文出現(xiàn)亂碼

最初在mybatis配置如下

<select id="queryContentById" resultType = "java.lang.String" parameterType="String" >
    select text from News where id=#{o} 
</select>

其中表News的text字段為blob類型

如此查出的text值在控制臺(tái)中一直顯示亂碼。

之后google查找相關(guān)resultType=blob相關(guān)內(nèi)容無果,遂將其改為resultType = "java.util.Map" ,且

byte[] b = (byte[]) map.get("text");
String s = new String(b,"utf-8");

打印出s,此時(shí)中文正常顯示,但頁面顯示依舊亂碼。

因此處為ajax請(qǐng)求,遂檢查響應(yīng)頭信息,查出如下

Content-Typetext/html;charset=ISO-8859-1

由于數(shù)據(jù)庫中統(tǒng)一為編碼為utf-8,故修改響應(yīng)頭信息

@RequestMapping(value = "/queryContentById", method = RequestMethod.GET,produces = "text/plain;charset=UTF-8")
public @ResponseBody String queryContentById(@RequestParam("id") String id) throws SQLException, UnsupportedEncodingException {
  Map map = (Map) ndrService.queryContentById(id);
  byte[] b = (byte[]) map.get("text");
  String s = new String(b,"utf-8");
  return s;
}

我們?cè)賮砜聪铝硗庖粋€(gè)示例的問題

1、SpringMVC的Controller得到的是亂碼:
(1)在web.xml加上字符集過濾器:

復(fù)制代碼 代碼如下:
 <!-- Spring字符集過濾器 --> <filter>  <filter-name>SpringEncodingFilter</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>  <init-param>   <param-name>forceEncoding</param-name>   <param-value>true</param-value>  </init-param> </filter> <filter-mapping>  <filter-name>SpringEncodingFilter</filter-name>  <url-pattern>/*</url-pattern> </filter-mapping>

(2)在JSP等頁面上修改:charset=UTF-8"和pageEncoding="UTF-8"

2、Controller讀取到的是正確的中文,但是保存到數(shù)據(jù)庫后變成“??”

(1)修改數(shù)據(jù)庫連接jdbc_url=jdbc:mysql://localhost:3306/mybatistest?useUnicode=yes&amp;characterEncoding=UTF8("&amp;":在xml文件中表示"&")

(2)修改數(shù)據(jù)庫的字符集為utf-8:打開mysql根目錄下my.ini(mysql5.6為my-default.ini,要把它c(diǎn)opy一份命名為my.ini),在下面具體位置添加(或修改):

復(fù)制代碼 代碼如下:
[mysqld]character-set-server=utf8 [client]default-character-set = utf8[mysql]default-character-set = utf8

這樣設(shè)置在我這邊就沒什么問題了。

綜述:

通常中文亂碼問題都是由于字符編碼設(shè)置不對(duì)導(dǎo)致的,我這里無論是數(shù)據(jù)庫還是java文件、jsp文件,都統(tǒng)一成UTF-8。最后問題解決了。

相關(guān)文章

  • 一文帶你深入了解Java8 Stream流式編程

    一文帶你深入了解Java8 Stream流式編程

    在實(shí)際項(xiàng)目當(dāng)中,若能熟練使用Java8 的Stream流特性進(jìn)行開發(fā),就比較容易寫出簡(jiǎn)潔優(yōu)雅的代碼。本文主要就是基于實(shí)際項(xiàng)目常用的Stream Api流式處理總結(jié),希望對(duì)大家有所幫助
    2023-04-04
  • java解析.yml文件方式

    java解析.yml文件方式

    這篇文章主要介紹了java解析.yml文件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • HashMap vs TreeMap vs Hashtable vs LinkedHashMap

    HashMap vs TreeMap vs Hashtable vs LinkedHashMap

    這篇文章主要介紹了HashMap vs TreeMap vs Hashtable vs LinkedHashMap的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • SpringCloud Config配置中心原理以及環(huán)境切換方式

    SpringCloud Config配置中心原理以及環(huán)境切換方式

    這篇文章主要介紹了SpringCloud Config配置中心原理以及環(huán)境切換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 解決for循環(huán)為空不需要判斷的問題

    解決for循環(huán)為空不需要判斷的問題

    這篇文章主要介紹了解決for循環(huán)為空不需要判斷的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Java外觀模式解讀,讓你的代碼優(yōu)雅又高效

    Java外觀模式解讀,讓你的代碼優(yōu)雅又高效

    外觀模式(Facade?Pattern)是一種常用的結(jié)構(gòu)型設(shè)計(jì)模式,它為復(fù)雜的子系統(tǒng)提供一個(gè)簡(jiǎn)單的接口,隱藏復(fù)雜的實(shí)現(xiàn)細(xì)節(jié),本文就來講講它是如何簡(jiǎn)化代碼,提高可維護(hù)性的
    2023-05-05
  • java使用httpclient模擬post請(qǐng)求和get請(qǐng)求示例

    java使用httpclient模擬post請(qǐng)求和get請(qǐng)求示例

    這篇文章主要介紹了java使用httpclient模擬post請(qǐng)求和get請(qǐng)求示例,需要的朋友可以參考下
    2014-02-02
  • spring cloud gateway請(qǐng)求跨域問題解決方案

    spring cloud gateway請(qǐng)求跨域問題解決方案

    這篇文章主要介紹了spring cloud gateway請(qǐng)求跨域問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Java實(shí)現(xiàn)CORS跨域請(qǐng)求的實(shí)現(xiàn)方法

    Java實(shí)現(xiàn)CORS跨域請(qǐng)求的實(shí)現(xiàn)方法

    本篇文章主要介紹了Java實(shí)現(xiàn)CORS跨域請(qǐng)求的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • 關(guān)于java編譯過程中的bug說明

    關(guān)于java編譯過程中的bug說明

    本篇文章是對(duì)java編譯過程中的bug進(jìn)行了詳細(xì)的說明介紹,需要的朋友參考下
    2013-05-05

最新評(píng)論