溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

發(fā)布時(shí)間:2020-06-24 06:32:54 來源:網(wǎng)絡(luò) 閱讀:739 作者:你都發(fā)了個(gè) 欄目:數(shù)據(jù)庫(kù)

這篇文章主要介紹了解決java中springmvc+mybatis+mysql中文亂碼問題的相關(guān)資料,需要的朋友可以參考下

近日使用ajax請(qǐng)求springmvc后臺(tái)查詢mysql數(shù)據(jù)庫(kù),頁面顯示中文出現(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" ,且

?

1

2

byte[] b = (byte[]) map.get("text");

String s = new String(b,"utf-8");

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

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

?

1

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


由于數(shù)據(jù)庫(kù)中統(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ù)庫(kù)后變成“??”

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

(2)修改數(shù)據(jù)庫(kù)的字符集為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ù)庫(kù)還是java文件、jsp文件,都統(tǒng)一成UTF-8。最后問題解決了。

  1. 1. 使用阿里巴巴Druid連接池(高效、功能強(qiáng)大、可擴(kuò)展性好的數(shù)據(jù)庫(kù)連接池、監(jiān)控?cái)?shù)據(jù)庫(kù)訪問性能、支持Common-Logging、Log4j和JdkLog,監(jiān)控?cái)?shù)據(jù)庫(kù)訪問)

  1. 2. 提供高并發(fā)JMS消息處理機(jī)制
    3. 所有功能模塊化、所有模塊服務(wù)化、所有服務(wù)原子化的方式,提供可拓展的服務(wù)模型,使程序穩(wěn)定運(yùn)行,永不宕機(jī)
    4. 提供Wink Rest、Webservice服務(wù),故可作為獨(dú)立服務(wù)平臺(tái)部署

    框架整合:

    Springmvc + Mybatis + Shiro(權(quán)限) + REST(服務(wù)) + WebService(服務(wù)) + JMS(消息) + Lucene(搜搜引擎) + Quartz(定時(shí)調(diào)度) + Bootstrap Html5(支持PC、IOS、Android)

    框架簡(jiǎn)介:


    項(xiàng)目Maven構(gòu)建,真實(shí)大型互聯(lián)網(wǎng)架構(gòu),做到高并發(fā),大數(shù)據(jù)處理,整個(gè)項(xiàng)目使用定制化服務(wù)思想,提供模塊化、服務(wù)化、原子化的方案,將功能模塊進(jìn)行拆分,可以公用到所有的項(xiàng)目中。架構(gòu)采用分布式部署架構(gòu),所有模塊進(jìn)行拆分,使項(xiàng)目做到絕對(duì)解耦,穩(wěn)定壓倒一切~~

    持續(xù)集成:

    1. 我的待辦工作流服務(wù)(提供Webservice服務(wù))

    2. 我的待辦工作流集成JMS消息服務(wù)(支持高并發(fā),可支持成千上萬系統(tǒng)集成)

    3. 我的任務(wù)提供Rest服務(wù),完成日常的工作管理,通過定時(shí)調(diào)度平臺(tái),動(dòng)態(tài)生成我的任務(wù)、循環(huán)周期任務(wù)、定時(shí)郵催提醒完成任務(wù)等

    4. 文件上傳、多線程下載服務(wù)化、發(fā)送郵件、短信服務(wù)化、部門信息服務(wù)化、產(chǎn)品信息服務(wù)化、信息發(fā)布服務(wù)化、我的訂閱服務(wù)化、我的任務(wù)服務(wù)化、公共鏈接、我的收藏服務(wù)化等

    系統(tǒng)模塊:

     1.  用戶管理:

          用戶信息管理(添加、刪除、修改、用戶授權(quán)、用戶欄目管理、查詢等)

          用戶組管理(添加、刪除、修改、用戶組欄目授權(quán),欄目授權(quán)、查詢、用戶組人員添加查詢等)

          用戶角色管理(添加、刪除、修改、用戶角色授權(quán)、用戶角色欄目信息查詢?cè)O(shè)置等)
     2.  文章管理:

          欄目管理:查詢無限極欄目樹、創(chuàng)建無限極欄目樹分類(導(dǎo)航欄目、圖片列表欄目、文章列表欄目、文章內(nèi)容欄目等)、刪除、修改欄目信息。

          文章管理:創(chuàng)建、刪除、修改文章,多維度文章查詢,包括已發(fā)布、未發(fā)布、所有文章等。文章富文本編輯器、文章多文件上傳、文章狀態(tài)控制等。
    3.  系統(tǒng)設(shè)置:

           數(shù)據(jù)字典管理:支持中、英文信息,支持無限級(jí)別分類配置,動(dòng)態(tài)控制是否可用等。

           部門信息管理:支持中、英文無限級(jí)別部門信息增加,刪除,修改操作,部門列表、樹心查詢等。

           日志管理:系統(tǒng)日志列表查詢、在線查看、在線下載等

           路線管理:集成百度地圖API,提供線路查詢管理功能

           Druid Monitor(監(jiān)控):集成阿里巴巴連接池,提供在線連接池監(jiān)控程序,包括:數(shù)據(jù)源、SQL監(jiān)控、URL監(jiān)控、Session監(jiān)控、Spring監(jiān)控等

           網(wǎng)站信息管理:通過系統(tǒng)配置文件進(jìn)行網(wǎng)站內(nèi)容操作,包括郵件服務(wù)器配置、公司基本信息配置等。

     4.  集成REST服務(wù),可以用作獨(dú)立服務(wù)平臺(tái)(提供大量實(shí)例及測(cè)試平臺(tái),包括:文件上傳下載、郵件短信發(fā)送、部門、產(chǎn)品、公共連接、我的收藏、我的任務(wù)、信息發(fā)布等)

     5.  集成Quartz調(diào)度可以用作定時(shí)調(diào)度平臺(tái)(動(dòng)態(tài)配置調(diào)度類、調(diào)度時(shí)間,使程序自動(dòng)執(zhí)行某些業(yè)務(wù))

     6.  Lucene搜索引擎,可以將文件資料索引化,支持文件內(nèi)容搜索、關(guān)鍵字搜索、高亮關(guān)鍵字等,使信息在毫秒內(nèi)提取查詢出來

     7.  用戶設(shè)置功能包括修改用戶信息,修改密碼、發(fā)送消息,修改個(gè)人圖片,查看角色、查看用戶組,管理員修改角色、用戶、用戶組等。

     8.  集成Webservice平臺(tái),包括jaxws服務(wù)、CXF框架,配置雙加密的權(quán)限認(rèn)證。使服務(wù)集成更加安全。

     9.  Bootstrap html5提供了兩套前臺(tái)開環(huán)境,包括CMS和電子商務(wù)網(wǎng)站,使您的開發(fā)更加的簡(jiǎn)潔。

    技術(shù)點(diǎn):

    1.  Springmvc + Mybatis集成、SpringSecurity權(quán)限控制、Spring AOP事務(wù)處理。

    2.   Wink Rest服務(wù)、Webservice服務(wù):jaxws、CXF等

    3.  IO 流上傳下載文件,多線程操作

    4.  發(fā)送郵件,配置郵件服務(wù)器,發(fā)基于html、純文本格式的郵件

    5.  MD5加密 (登陸密碼校驗(yàn)加密等),用戶統(tǒng)一Session、Cookie管理,統(tǒng)一驗(yàn)證碼校驗(yàn)等。

    6.  數(shù)據(jù)庫(kù)連接池統(tǒng)一配置 

    7.  Quartz定時(shí)調(diào)度任務(wù)集成(直接通過配置即可)

    8.  Httpclient破解驗(yàn)證碼,登陸聯(lián)通充值平臺(tái)

    9.  漢字、英文拆分、可以用作文檔關(guān)鍵字搜索等。

    10.  Base64圖片處理,支持PC,Android,IOS

    11.  Service Socket 、Client Socket 通信技術(shù)(已經(jīng)做過GPRS數(shù)據(jù)獲取,并用到了項(xiàng)目中)

    12.  提供大量工具類,可以直接使用

    13.  Maven項(xiàng)目構(gòu)建,您可以直接做架構(gòu),可以提升自己的學(xué)習(xí)能力,使您成為真正的架構(gòu)師。


    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】
     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】  解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】
     

     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】  解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】
     

     解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】
     

    解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】  解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】

     解決springmvc+mybatis+mysql中文亂碼問題【轉(zhuǎn)】


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI