eclipse往mysql里面插入數據時的亂碼&傳值亂碼


其實解決這個問題就是要保證整個數據插入過程中字符編碼要一致。要有三個方面注意的,

第一個是msyl數據庫,就是保證mysql的數據庫以及表都要保證編碼是一致的比如都是UTF-8,

第二個是,eclipse這邊也要保證項目,工作空間和java文件的編碼格式也是UTF-8,

第三個是,就是配置文件里面jdbc的url的(jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf8)后面也要設置編碼characterEncoding=utf8(這個問題以前沒遇到,這次出現亂碼最后才發現是他的緣故) 

第四個是,jsp頁面傳值過程中可能亂碼,<%request.setCharacterEncoding("UTF-8"); %>,防止頁面傳值的時候亂碼————————————————————————————————————————————------

1、針對Post方式提交的請求如果出現亂碼,可以每次在request解析數據時設置編碼格式:

request.setCharacterEncoding("utf-8");

也可以使用編碼過濾器來解決,最常用的方法是使用spring提供的編碼過濾器:

在Web.xml中增加如下配置(要注意的是它的位置一定要是第一個執行的過濾器):

<filter>
<filter-name>charsetFilter</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>

該過濾器要做的其實就是強制為所有請求和響應設置編碼格式:

request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");

2、針對Get方式的亂碼問題,由於參數是通過URL傳遞的,所以上面通過request設置的編碼格式是不起作用的,此時可以在每次發生請求之前對URL進行編碼:例如:Location.href="/encodeURI"("http://localhost/test/s?name=中文&sex=女");

當然也有更簡便的方法,那就是在服務器端配置URL編碼格式:

修改tomcat的配置文件server.xml:
             <Connector URIEncoding="UTF-8" 
                 port="8080"   maxHttpHeaderSize="8192"
               maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
               connectionTimeout="20000" disableUploadTimeout="true" />

只需增加 URIEncoding="UTF-8"  這一句,然后重啟tomcat即可。 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM