數據庫連接出現亂碼
這種亂碼會使你插入數據庫的中文變成亂碼,或者讀出顯示時也是亂碼,解決方法如下: 在數據庫連接字符串中加入編碼字符集
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");
關於jsp在MyEclipse中打開的亂碼問題
對於一個已經存在的項目,Jsp文件的存儲格式可能是utf-8。如果新安裝的eclipse,則缺省打開使用的編碼格式可能iso8859-1。所以導致 jsp裏面的漢字出現亂碼。這個亂碼魚解決方式如下:
A、Myeclispe Window - > Preferences彈出屬性窗口
General - > Workspace 設置Text file encoding 全局設置。
B、右鍵你的項目---屬性---Text file encoding 項目設置
關於html頁面在eclipse中打開出現亂碼情況
由於大部分頁面都是由dreamweaver製作,其存儲格式跟eclipse的識別有差別導致。
一般這種情況,在eclipse中新建一個jsp,直接從dreamweaver複製頁面內容粘貼到jsp即可。
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"));
%>