在eclipse裏面咱們的jsp頁面若是咱們寫了中文,保存的時候會彈出一個框,讓你選擇保存方式,之因此這樣是由於jsp默認的文件編碼是ISO-8859-1字符集中無中文字符。html
一個比較好的解決辦法是在這個jsp頁面的開頭添加以下一句:java
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" %>
就能夠保存了,切在服務器運行了以後,再去頁面瀏覽的時候也是正常的,中文也不會亂碼 web
下面關於jsp中文亂碼作一個詳細的總結和概述,是一個總結的很是好的博客,我直接貼過來的,值得借鑑:sql
你們在JSP的開發過程當中,常常出現中文亂碼的問題,可能一至困擾着你們,現把JSP開發中遇到的中文亂碼的問題及解決辦法寫出來供你們參考。首先了解一下Java中文問題的由來:數據庫
Java的內核和class文件是基於unicode的,這使Java程序具備良好的跨平臺性,但也帶來了一些中文亂碼問題的麻煩。緣由主要有兩方面,Java和JSP文件自己編譯時產生的亂碼問題和Java程序於其餘媒介交互產生的亂碼問題。首先Java(包括JSP)源文件中極可能包含有中文,而Java和JSP源文件的保存方式是基於字節流的,若是Java和JSP編譯成class文件過程當中,使用的編碼方式與源文件的編碼不一致,就會出現亂碼。基於這種亂碼,建議在Java文件中儘可能不要寫中文(註釋部分不參與編譯,寫中文不要緊),若是必須寫的話,儘可能手動帶參數-ecoding GBK或-ecoding gb2312或-ecoding UTF-8編譯;對於JSP,在文件頭加上<%@ page contentType="text/html;charset=GBK"%>或瀏覽器
<%@ page contentType="text/html;charset=gb2312"%>基本上就能解決這類亂碼問題。tomcat
下面是一些常見中文亂碼問題的解決方法(下面例子中ecoding採用的是gb2312,也可設爲ecoding GBK或ecoding UTF-8):服務器
1、 JSP頁面亂碼app
這種亂碼問題比較簡單,通常是頁面編碼不一致致使的亂碼,通常新手容易出現這樣的問題,具體分如下兩種狀況:eclipse
Ø 未指定使用字符集編碼
下面的顯示頁面(display.jsp)就出現亂碼:
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html charset=gb2312">
</head>
<body>
<%out.print("JSP的中文處理");%>
</body>
</html>
這種亂碼的緣由是沒有在頁面裏指定使用的字符集編碼,JSP頁面中出現了中文字符,而默認的ISO-8859-1字符集中無中文字符,解決方法:只要在頁面開始地方用下面代碼指定字符集編碼便可,在JSP頁面中指定編碼方式(gb2312),和瀏覽器解碼方式設置相同,即在頁面的第一行加上:
<%@ page contentType="text/html; charset=gb2312"%>,就能夠消除亂碼了。
完整頁面以下:
<%@ page contentType="text/html; charset=gb2312"%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html charset=gb2312">
</head>
<body>
<%out.print("JSP的中文處理");%>
</body>
</html>
Ø 編碼字符集設置不一致
下面的顯示頁面(display.jsp)就出現亂碼:
<%@ page language="java" pageEncoding="gb2312"%>
<%@ page contentType="text/html;charset=iso8859-1"%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html charset=gb2312">
</head>
<body>
<%out.print("JSP的中文處理");%>
</body>
</html>
這個出現亂碼緣由是因爲頁面編碼不一致致使的亂碼,在這個例子中咱們能夠看到有三處設置字符集的地方,下面分別瞭解一下這三處設置具體含義:
第一處<%@ page language="java" pageEncoding="gb2312"%>的編碼格式爲jsp文件的存儲格式。Eclipse會根據這個編碼格式保存文件。並編譯jsp文件,包括裏面的漢字。
第二處編碼爲解碼格式。由於存爲gb2312的文件被解碼爲iso8859-1,這樣若有中文確定出亂碼。也就是必須一致。而第二處所在的這一行,能夠沒有。缺省也是使用iso8859-1的編碼格式。因此若是沒有這一行的話,也會出現亂碼。必須一致才能夠。
第三處編碼爲控制瀏覽器的解碼方式。若是前面的解碼都一致而且無誤的話,這個編碼格式用不用設置均可以。有的網頁出現亂碼,就是由於瀏覽器不能肯定使用哪一種編碼格式。由於頁面有時候會嵌入頁面,致使瀏覽器混淆了編碼格式出現了亂碼。
完整解決代碼以下:
<%@ page language="java" pageEncoding="gb2312"%>
<%@ page contentType="text/html;charset= gb2312"%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html charset=gb2312">
</head>
<body>
<%out.print("JSP的中文處理");%>
</body>
</html>
2、 表單提交中文時出現亂碼
下面是一個提交頁面(submit.jsp),代碼以下:
<%@ page contentType="text/html; charset=gb2312"%>
<html>
<head><title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<form name="form1" method="post/get" action="process.jsp">
<div align="center">
<input type="text" name="name">
<input type="submit" name="Submit" value="Submit">
</div>
</form>
</body>
</html>
下面是處理頁面(process.jsp)代碼:
<%@ page contentType="text/html; charset=gb2312"%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<%=request.getParameter("name")%>
</body>
</html>
若是submit.jsp提交英文字符能正確顯示,若是提交中文時就會出現亂碼。緣由:瀏覽器默認使用UTF-8編碼方式來發送請求,而UTF- 8和GB2312編碼方式表示字符時不同,這樣就出現了不能識別字符。
Ø POST提交方式
解決辦法:
A、 接受參數時進行編碼轉換
String s=new String(request.getParameter("name").getBytes("ISO-8859-1"),"gb2312") ;
修改後的process.jsp代碼以下:
<%@ page contentType="text/html; charset=gb2312"%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<%
String s=new String(request.getParameter("name").getBytes("ISO-8859-1"),"gb2312") ;
out.print(s);
%>
</body>
</html>
若是使用該方法的話,每個參數都必須這樣進行轉碼。很麻煩。但確實能夠拿到漢字。
B、經過request.seCharacterEncoding ("gb2312")對請求進行統一編碼,就實現了中文的正常顯示。
修改後的process.jsp代碼以下:
<%@ page contentType="text/html; charset=gb2312"%>
<%request.seCharacterEncoding("gb2312");%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<%=request.getParameter("name")%>
</body>
</html>
若是使用該方法接受此參數的頁面就沒必要在轉碼了,便可獲得漢字參數。但每頁都須要執行這句話。
C、爲了不每頁都要寫request.setCharacterEncoding("gb2312"),可使用過濾器對全部jsp
進行編碼處理。就是使用Servlet規範中的過慮器指定編碼,主要代碼以下:
import java.io.*;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class SetCharacterEncodingFilter implements Filter {
protected String encoding = null;
public void destroy(){
this.encoding = null;
}
public void init(FilterConfig filterConfig) throws ServletException
{
this.encoding = filterConfig.getInitParameter("encoding");
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException
{
request.setCharacterEncoding(encoding);
response.setContentType("text/html;charset="+encoding);
chain.doFilter(request, response);
}
}
過濾器在web.xml中的配置以下:
<filter>
<filter-name>SetCharacterEncodingFilter</filter-name>
<filter-class>SetCharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>gb2312</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>SetCharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
修改後的process.jsp代碼以下:
<%@ page contentType="text/html; charset=gb2312"%>
<html>
<head>
<title>JSP的中文處理</title>
</head>
<body>
<%=request.getParameter("name")%>
</body>
</html>
以上方法只對POST方式提交有效果。
Ø GET提交方式
若是使用get方式提交中文,接受參數的頁面也會出現亂碼,這個亂碼的緣由也是tomcat的內部編碼格式iso8859-1致使。Tomcat會以get的缺省編碼方式iso8859-1對漢字進行編碼,編碼後追加到url,致使接受頁面獲得的參數爲亂碼。
解決辦法:
A、 使用POST提交方式解決辦法的第一種方式,對接受到的字符進行解碼,再轉碼。
B 、首先配置tomcat下server.xml的Connector節點增長useBodyEncodingForURI="true"屬性配置,而後在JSP頁面中加入<%request.seCharacterEncoding("gb2312");%>所設置的編碼格式進行編碼。
一、Tomcat中server.xml配置以下:
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
useBodyEncodingForURI="true"
/>
二、修改後的process.jsp代碼以下:
<%@ page contentType="text/html; charset=gb2312"%>
<%request.seCharacterEncoding("gb2312");%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<%=request.getParameter("name")%>
</body>
</html>
3、數據庫鏈接出現亂碼
這種亂碼會使你插入數據庫的中文變成亂碼,或者讀出顯示時也是亂碼,解決方法以下: 在數據庫鏈接字符串中加入編碼字符集
String Url=" jdbc:sqlserver://localhost:1433; DataBaseName=mydb;user=sa&password=sa&useUnicode=true&characterEncoding=GB2312";
並在JSP頁面中使用以下代碼:
response.setContentType("text/html;charset=gb2312"); request.setCharacterEncoding("gb2312");
4、關於jsp在MyEclipse中打開的亂碼問題
對於一個已經存在的項目,Jsp文件的存儲格式多是utf-8。若是新安裝的eclipse,則缺省打開使用的編碼格式可能iso8859-1。因此致使 jsp裏面的漢字出現亂碼。這個亂碼魚解決方式以下:
A、Myeclispe Window - > Preferences彈出屬性窗口
General - > Workspace 設置Text file encoding 全局設置。
B、右鍵你的項目---屬性---Text file encoding 項目設置
5、關於html頁面在eclipse中打開出現亂碼狀況
因爲大部分頁面都是由dreamweaver製做,其存儲格式跟eclipse的識別有差異致使。
通常這種狀況,在eclipse中新建一個jsp,直接從dreamweaver複製頁面內容粘貼到jsp便可。
6、JSP頁面經過URL傳遞中文參數的亂碼問題
在項目中,咱們常常遇到須要在jsp頁面切換中傳遞中文字符。例如:http://website/test1.jsp?act=add&type=蘋果
Ø 通常來講咱們不多直接在URL裏面把參數寫成中文,如例子中的"type=蘋果"這樣傳遞。若是出現這種狀況,在咱們的接收參數的頁面咱們只須要作個簡單的轉換就能夠了。
代碼test1.jsp:(主要部分)
<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%
String type = request.getParameter("type");
String result = new String(type.getBytes("iso-8859-1"), "gb2312");
out.println(result);
%>
Ø 更廣泛的作法,就是對url中的中文字符進行編碼,變成相似type=%20D%20B這樣的字符。
代碼MyJsp1.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@ page import="java.net.*" %>
<a href='./MyJsp2.jsp?act=<%=URLEncoder.encode("中國人 很是好")%>'>test</a>
代碼MyJsp2.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@ page import="java.net.*" %>
<%
String tempVal = URLDecoder.decode(request.getParameter("act"));
out.println(new String(tempVal.getBytes("ISO-8859-1"), "gb2312"));
%>