1. 程式人生 > >tomcat亂碼解決方案 tomcat 亂碼

tomcat亂碼解決方案 tomcat 亂碼

這些天開發一個專案,伺服器是tomcat,作業系統是xp,採用的是MVC架構,模式是採用Facade模式,總是出現亂碼,自己也解決了好多天,同事也幫忙解決,也參考了網上眾多網友的文章和意見,總算是搞定。但是好記性不如爛筆桿,所以特意記下,以防止自己遺忘,同時也給那些遇到同樣問題的人提供一個好的參考途徑:
(一)         JSP頁面上是中文,但是看的是後是亂碼:
解決的辦法就是在JSP頁面的編碼的地方<%@ page language="java" contentType="text/html;charset=GBK" %>,因為Jsp轉成Java檔案時的編碼問題,預設的話有的伺服器是ISO-8859-1,如果一個JSP中直接輸入了中文,Jsp把它當作ISO8859-1來處理是肯定有問題的,這一點,我們可以通過檢視Jasper所生成的Java中間檔案來確認
(二)         當用Request物件獲取客戶提交的漢字程式碼的時候,會出現亂碼:
解決的辦法是:要配置一個filter,也就是一個Servelet的過濾器,程式碼如下:
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.UnavailableException;

/**
* Example filter that sets the character encoding to be used in parsing the
* incoming request
*/
public class SetCharacterEncodingFilter implements Filter {

     /**
     * Take this filter out of service.
     */
     public void destroy() {
     }
     /**
     * Select and set (if specified) the character encoding to be used to
     * interpret request parameters for this request.
     */
     public void doFilter(ServletRequest request, ServletResponse response,
     FilterChain chain)throws IOException, ServletException {

     request.setCharacterEncoding("GBK");

     // 傳遞控制到下一個過濾器
     chain.doFilter(request, response);
     }

     public void init(FilterConfig filterConfig) throws ServletException {
     }
}
配置web.xml
<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>SetCharacterEncodingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
如果你的還是出現這種情況的話你就往下看看是不是你出現了第四中情況,你的Form提交的資料是不是用get提交的,一般來說用post提交的話是沒有問題的,如果是的話,你就看看第四中解決的辦法。
還有就是對含有漢字字元的資訊進行處理,處理的程式碼是:
package dbJavaBean;

public class CodingConvert
{  
public CodingConvert()
{
   //
}
public String toGb(String uniStr){
     String gbStr = "";
     if(uniStr == null){
   uniStr = "";
     }
     try{
   byte[] tempByte = uniStr.getBytes("ISO8859_1");
   gbStr = new String(tempByte,"GB2312");
     }
   catch(Exception ex){
     }
     return gbStr;
}
  
public String toUni(String gbStr){
     String uniStr = "";
     if(gbStr == null){
   gbStr = "";
     }
     try{
   byte[] tempByte = gbStr.getBytes("GB2312");
   uniStr = new String(tempByte,"ISO8859_1");
     }catch(Exception ex){
     }
     return uniStr;
}
}
你也可以在直接的轉換,首先你將獲取的字串用ISO-8859-1進行編碼,然後將這個編碼存放到一個位元組陣列中,然後將這個陣列轉化成字串物件就可以了,例如:
String str=request.getParameter(“girl”);
Byte B[]=str.getBytes(“ISO-8859-1”);
Str=new String(B);
通過上述轉換的話,提交的任何資訊都能正確的顯示。
(三)         在Formget請求在服務端用request. getParameter(“name”)時返回的是亂碼;按tomcat的做法設定Filter也沒有用或者用request.setCharacterEncoding("GBK");也不管用問題是出在處理引數傳遞的方法上:如果在servlet中用doGet(HttpServletRequest request, HttpServletResponse response)方法進行處理的話前面即使是寫了:
request.setCharacterEncoding("GBK");
response.setContentType("text/html;charset=GBK");
也是不起作用的,返回的中文還是亂碼!!!如果把這個函式改成doPost(HttpServletRequest request, HttpServletResponse response)一切就OK了。
同樣,在用兩個JSP頁面處理表單輸入之所以能顯示中文是因為用的是post方法傳遞的,改成get方法依舊不行。
由此可見在servlet中用doGet()方法或是在JSP中用get方法進行處理要注意。這畢竟涉及到要通過瀏覽器傳遞引數資訊,很有可能引起常用字符集的衝突或是不匹配。
解決的辦法是:
1) 開啟tomcat的server.xml檔案,找到區塊,加入如下一行:
URIEncoding=”GBK”
完整的應如下:
<Connector port="8080" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="GBK"/>

2)重啟tomcat,一切OK。
需要加入的原因大家可以去研究 $TOMCAT_HOME/webapps/tomcat-docs/config/http.html下的這個檔案就可以知道原因了。需要注意的是:這個地方如果你要是用UTF-8的時候在傳遞的過程中在Tomcat中也是要出現亂碼的情況,如果不行的話就換別的字符集。

(四)         JSP頁面上有中文,按鈕上面也有中文,但是通過伺服器檢視頁面的時候出現亂碼:
     解決的辦法是:首先在JSP檔案中不應該直接包含本地化的訊息文字,而是應該通過<bean:message>標籤從Resource Bundle中獲得文字。應該把你的中文文字放到Application.properties檔案中,這個檔案放在WEB-INF/classes/*下,例如我在頁面裡有姓名,年齡兩個label,我首先就是要建一個Application.properties,裡面的內容應該是name=”姓名” age=”年齡”,然後我把這個檔案放到WEB-INF/classes/properties/下,接下來根據Application.properties檔案,對他進行編碼轉化,建立一箇中文資原始檔,假定名字是Application_cn.properties。在JDK中提供了native2ascii命令,他能夠實現字元編碼的轉換。在DOS環境中找到你放置Application.properties的這個檔案的目錄,在DOS環境中執行一下命令,將生成按GBK編碼的中文資原始檔Application_cn.properties:native2ascii –encoding gbk Application.properties Application_cn.properties執行以上命令以後將生成如下內容的Application_cn.properties檔案:name=/u59d3/u540d age=/u5e74/u9f84,在Struts-config.xml中配置:<message-resources parameter="properties.Application_cn"/>。到這一步,基本上完成了一大半,接著你就要在JSP頁面上寫<%@ page language="java" contentType="text/html;charset=GBK" %>,到名字的那個label是要寫<bean:message key=”name”>,這樣的化在頁面上出現的時候就會出現中文的姓名,年齡這個也是一樣,按鈕上漢字的處理也是同樣的。
(五)         寫入到資料庫是亂碼:
解決的方法:要配置一個filter,也就是一個Servelet的過濾器,程式碼如同第二種時候一樣。
如果你是通過JDBC直接連結資料庫的時候,配置的程式碼如下:jdbc:mysql://localhost:3306/workshopdb?useUnicode=true&characterEncoding=GBK,這樣保證到資料庫中的程式碼是不是亂碼。
如果你是通過資料來源連結的化你不能按照這樣的寫法了,首先你就要寫在配置檔案中,在tomcat 5.0.19中配置資料來源的地方是在C:/Tomcat 5.0/conf/Catalina/localhost這個下面,我建立的工程是workshop,放置的目錄是webapp下面,workshop.xml的配置檔案如下:
<!-- insert this Context element into server.xml -->

<Context path="/workshop" docBase="workshop" debug="0"
reloadable="true" >

   <Resource name="jdbc/WorkshopDB"
               auth="Container"
               type="javax.sql.DataSource" />

   <ResourceParams name="jdbc/WorkshopDB">
     <parameter>
       <name>factory</name>
       <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
     </parameter>
     <parameter>
       <name>maxActive</name>
       <value>100</value>
     </parameter>
     <parameter>
       <name>maxIdle</name>
       <value>30</value>
     </parameter>

    
     <parameter>
       <name>maxWait</name>
       <value>10000</value>
     </parameter>

       <parameter>
     <name>username</name>
     <value>root</value>
     </parameter>
     <parameter>
     <name>password</name>
     <value></value>
     </parameter>

     <!-- Class name for mm.mysql JDBC driver -->
     <parameter>
       <name>driverClassName</name>
       <value>com.mysql.jdbc.Driver</value>
</parameter>
   <parameter>
       <name>url</name>
<value><![CDATA[jdbc:mysql://localhost:3306/workshopdb?useUnicode=true&characterEncoding=GBK]]></value>
     </parameter>
   </ResourceParams>

</Context>
粗體的地方要特別的注意,和JDBC直接連結的時候是有區別的,如果你是配置正確的化,當你輸入中文的時候到資料庫中就是中文了,有一點要注意的是你在顯示資料的頁面也是要用<%@ page language="java" contentType="text/html;charset=GBK" %>這行程式碼的。需要注意的是有的前臺的人員在寫程式碼的是後用Dreamver寫的,寫了一個Form的時候把他改成了一個jsp,這樣有一個地方要注意了,那就是在Dreamver中Action的提交方式是request的,你需要把他該過來,因為在jsp的提交的過程中緊緊就是POST和GET兩種方式,但是這兩種方式提交的程式碼在編碼方面還是有很大不同的,這個在後面的地方進行說明。3

以上就是我在開發系統中解決中文的問題,不知道能不能解決大家的問題,時間匆忙,沒有及時完善,文筆也不是很好,有些地方估計是詞不達意。大家可以給我意見,希望能共同進步。

相關推薦

tomcat亂碼解決方案 tomcat 亂碼

這些天開發一個專案,伺服器是tomcat,作業系統是xp,採用的是MVC架構,模式是採用Facade模式,總是出現亂碼,自己也解決了好多天,同事也幫忙解決,也參考了網上眾多網友的文章和意見,總算是搞定。但是好記性不如爛筆桿,所以特意記下,以防止自己遺忘,同時也給那些遇到同樣

SSM +tomcat 中前端ajax請求引數傳送後臺亂碼解決方案

後臺接受前端請求引數顯示SQL Creating a new SqlSession Registering transaction synchronization for SqlSession [[email protected]] JDBC Conn

IDEA開發Struts2和Tomcat中文亂碼解決方案

idea struts2中文亂碼。idea tomcat中文亂碼。 1.很可能是寫有中文的Java檔案編碼和前端不一樣導致。 統一為UTF-8編碼: jsp檔案 <%@ page contentType="text/html;charset=UTF-8" pag

資料庫中文亂碼解決方案總結,tomcat+mysql+hibernate

我的開發環境是eclipse+tomcat+mysql+hibernate,資料落地時發現中文都成了?,網上一搜,原因有很多,這邊總結下,大家碰到可以按著一一排查: 一般編碼都會常用UTF-8編碼 1. 資料庫編碼 檢視mysql資料的的編碼,確實是utf-8 如

Linux下檢視tomcat日誌及亂碼解決方案

檢視日誌:tail -f catalina.out [Linux日誌亂碼][linux中使用tail -f檢視日誌出現中文亂碼的解決方案][linux中檢視tomcat日誌亂碼的解決方案][linux客戶端中文亂碼問題Xshell] 1、vim修改伺服器編碼,把編碼項改為  "zh_CN.UTF-8

windows下在Eclipse中啟動的tomcat沒有亂碼,單獨部署到tomcat亂碼解決方案

今天遇到了一個很奇怪的問題,在Eclipse中除錯,執行專案一切正常,專案的所有編碼都是統一的UTF-8。但是在單獨部署到tomcat上的時候出現了中文亂碼。 問題來源,這個是我用ckeditor編輯的頁面提交到後臺的 提交之後將資料儲存到資料庫。

tomcat伺服器,url get請求中文亂碼解決方案

解決方法,在tomcat conf/server.xml 中新增 紅色部分,然後重啟服務即可。     <Connector port="8080" protocol="HTTP/1.1" 

使用myeclipse插入資料到mysql 出現中文亂碼|utf8亂碼解決方案[適合tomcat部署的jsp應用]

java類: CharacterEncodingFilter import javax.servlet.*; import java.io.IOException; public class CharacterEncodingFilter impleme

ubuntu MySQL數據庫輸入中文亂碼 解決方案

title str itl alt 查詢 ref cte class nbsp 一、登錄MySQL查看用SHOW VARIABLES LIKE ‘character%’;下字符集,顯示如下:+--------------------------+--------------

oracle服務端與客戶端字符集不同導致中文亂碼解決方案

use 修改環境變量 描述 image nls_lang oracle服務 環境 分析 導致 1.問題描述 用pl/sql登錄時,會提示“數據庫字符集(ZHS16GBK)和客戶端字符集(2%)是不同的,字符集轉化可能會造成不可預期的後果”,具體問題是中文亂碼,如下圖 2.

Python HTTP庫requests中文頁面亂碼解決方案

獲得 使用 http text odin 抽取 from Coding blog 把html編碼類型賦與獲取到文本 獲取html編碼類型: 1.使用apparent_encoding可以獲得真實編碼 1 >>> response.apparent_enc

亂碼解決方案 2017.10.25

port src nco proto 解決方案 enc rec out ges <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIE

PHPWAMP亂碼一鍵解決,PHP亂碼通用解決方案/網站亂碼的多種原因分析

php亂碼 亂碼解決方案 php亂碼原因分析 所有引起網頁亂碼的原因,我將其劃分以下五大類1、服務器強制編碼造成的亂碼(此亂碼的表現:通常只會引起某個PHP版本亂碼(因為默認配置不同),建議使用PHPWAMP內置的常用工具萬能亂碼修復器,該修復器可以一鍵解決多種亂碼情況)2、頁面編碼聲明和頁面文檔

JSOUP教程,JSOUP 亂碼處理,JSOUP生僻字亂碼解決方案

catch 緩存 dem 頭信息 win64 -- 默認 set 開啟 JSOUP亂碼情況產生 這幾天我用 JSOUP 多線程的方式,爬取了200 多萬數據,數據為各地的地名相關。結果有小部分數據,不到 1 萬亂碼。我先檢查了我的編碼為UTF-8 ,覺得應該沒有問題。代碼基

「部署日記」Android Studio亂碼解決方案

安裝 roi 技術分享 set fff setting 電腦 span conf 弄了一臺新電腦,第一件事肯定是弄好打造臺啦 於是VS、AS、CRD、NSIS、Adobe全家桶全安裝完畢, 問題來了,在打開Android Studio時,出現亂碼,比如 這樣的: 這樣的:

MySQL數據庫中的中文亂碼解決方案

中文亂碼 數據庫MySQL 數據庫中輸入中文容易出現亂碼?(亂碼問題本源:參見http://blog.51cto.com/12042068/2115021)解決方法:1.在建表建庫的時候就指定默認編碼 utf8. CREATE TABLE table_name (

centos文件名亂碼解決方案

linu redirect connector 如果 mil http install toc 解決 解決CentOS7中文語言亂碼 在tomcat 中配置端口的地方添加 URIEncoding Connector port="80" protocol="HTTP/1.

LoadRunner接口HTTP請求中中文亂碼解決方案

空格 con value 發送 nbsp toe string ner 字符串 今天項目經理要求壓一下實時代扣接口性能。那就開始寫腳本,腳本寫好調試發現接口請求參數姓名輸入中文亂碼。接著就網上找資料解決該問題。 1:想法:將中文轉成UTF-8,lr_convert_stri

VIM顯示亂碼解決方案

解碼 參考 網絡傳輸 .net int 字節 每一個 nco 配置 字符集(charset) 代碼點(code point) 以ASCII為例,它為每一個字符分配一個數字序號,比如A的編碼點是65,所有代碼點的集合就叫字符集 字符編碼(char encoding) 字符編碼

詳解MySQL用戶與授權、MySQL日誌管理、數據亂碼解決方案

服務 defaults 速查 col pda pro 創建 接下來 方案 數據庫是信息系統中非常重要的環節,合理高效的對它進行管理是很重要的工作。通常是由總管理員創建不同的管理賬戶,然後分配不同的操作權限,把這些賬戶交給相應的管理人員使用。本篇我們在CentOS7.5操作系