您好,登錄后才能下訂單哦!
這篇文章主要介紹了解決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 |
|
打印出s,此時(shí)中文正常顯示,但頁面顯示依舊亂碼。
因此處為ajax請(qǐng)求,遂檢查響應(yīng)頭信息,查出如下
?
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. 使用阿里巴巴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ù)訪問)
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)師。
免責(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)容。