第一篇:phpmyadmin亂碼問題
phpmyadmin亂碼問題____2012年12月6日 09:39:16
首先,如果你出現(xiàn)亂碼,你一定baidu了文章,對于各種答案,肯定是頭都大了,說的都差不多,卻都不一樣煩啊。問題敘述:
1,從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示亂碼,在網(wǎng)頁輸出是好的2,直接從數(shù)據(jù)庫插入數(shù)據(jù),但是輸出到網(wǎng)頁后是亂碼
3,從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示正確,但是網(wǎng)頁輸出是亂碼。
對于亂碼問題就這三種了吧!
今天我親自試驗(yàn)了一下,下面公布我的結(jié)果(我用的是UTF-8,其他同理,UTF-8特別注意)
總述,亂碼,原因,編碼不一致,為什么?答曰:提交數(shù)據(jù)庫的數(shù)據(jù)需要編碼,數(shù)據(jù)庫存儲需要編碼,從數(shù)據(jù)庫提取的數(shù)據(jù)還需要編碼。這三種編碼需要一致!
首先,你要保證所有輸出輸入網(wǎng)頁都有編碼聲明
或者
header(“Content-Type: text/html;charset=utf-8”);
header(“Content-Type: text/html;charset=utf-8”);
注意!這里是utf-8,不是utf8
其次,相應(yīng)數(shù)據(jù)的編碼整理應(yīng)該為utf8_general_ci。
1、從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示亂碼,在網(wǎng)頁輸出是好的,說明提交的數(shù)據(jù)和數(shù)據(jù)庫的編碼不一樣,提取數(shù)據(jù)的編碼和提交數(shù)據(jù)的編碼一樣 A->B->A型
這你就懂了吧,A是提交和提取數(shù)據(jù)的編碼,B是數(shù)據(jù)庫存儲用的編碼。
修改方法: 如果你不是新手的話,數(shù)據(jù)庫連接文件應(yīng)該是單獨(dú)的吧比如execut_dql()(供查詢用)或者execut_dml()(供修改用),所有的語句應(yīng)該都是通過這兩個函數(shù)進(jìn)行的所以在這兩個函數(shù)里的第一行,先寫上mysql_query(“SET NAMES 'utf8'”);注意!是utf8,不是utf-8
例如下面的(在mysql_query()你的SQL語句之前,全部 SET NAME 'utf8'一下)
mysql_query(“SET NAMES 'utf8'”);
$res=mysql_query($sql,$this->conn)ordie(mysql_error());
mysql_query(“SET NAMES 'utf8'”);$res=mysql_query($sql,$this->conn)or die(mysql_error());
其實(shí),你把所以關(guān)于數(shù)據(jù)庫查詢、插入的語句前全部mysql_query(“SET NAMES 'utf8'”);后,亂碼問題就已經(jīng)解決了,不過你以前插入的數(shù)據(jù)要重新插入了。
2、直接從數(shù)據(jù)庫插入數(shù)據(jù),但是輸出到網(wǎng)頁后是亂碼。B->A型
這個不用再說了吧,你把查詢語句前先
mysql_query(“SET NAMES 'utf8'”);
//你的查詢
之后刷新下就不是亂碼了。
3、從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示正確,但是網(wǎng)頁輸出是亂碼。A->A->B型
同上,你把查詢語句前先
mysql_query(“SET NAMES 'utf8'”);
之后刷新下就不是亂碼了。
所以總結(jié)出,只要保證操作過程中,輸入,存儲,輸出的字符編碼一致,你想讓他亂碼都難
第二篇:struts處理中文亂碼問題總結(jié)
http://58andy.sinaapp.com 學(xué)了很久的java,接觸SSH也有一段時間了,寫成博文總是有點(diǎn)懶,最近在整理一些思緒,把SSH一點(diǎn)一滴放進(jìn)博客里,以備以后改進(jìn),再學(xué)習(xí)。
以我自己的了解,在進(jìn)行struts開發(fā)的過程中,總也是出現(xiàn)很多的亂碼問題,但歸根到底,也只是以下三種情況:
㈠頁面顯示中文亂碼
㈡?zhèn)鬟f參數(shù)中文亂碼
㈢國際化資源文件亂碼
下面就這三中情況介紹怎么在具體項(xiàng)目中處理這些亂碼問題。而對于整體的處理思想,是要統(tǒng)一編碼為: UTF-8.(以myeclipse6支持的struts1.3為準(zhǔn))
㈠頁面顯示中文亂碼
對于在頁面中顯示出現(xiàn)亂碼,這個問題比較簡單,便是檢查你的JSP文件里是不是出現(xiàn)了中文要處理,因?yàn)镴SP默認(rèn)的編碼格式為“ISO-8859-1”,當(dāng)JSP中出現(xiàn)要處理的中文時,其顯示就出現(xiàn)亂碼了,這種情況一般出現(xiàn)在手寫JSP,或修改時。因?yàn)樵趍yeclipse6.0中,如果出現(xiàn)了編碼錯誤時,程序不會讓你保存,而是會提示你注意編碼,這點(diǎn)很好。具體的修改辦法是把 Html代碼
1.<%.@ page language=“java” import=“java.util.” pageEncoding=“ISO-8859-1”>
改成:
Html代碼
1.<%.@ page language=“java” import=“java.util.” pageEncoding=“UTF-8”>
㈡?zhèn)鬟f參數(shù)中文亂碼
傳遞參數(shù)出現(xiàn)的亂碼,參數(shù)的內(nèi)容為中文。比如在struts應(yīng)用中,簡單的一個登錄界面中,需要傳遞的登錄名為中文時,你沒經(jīng)處理之前,是會出現(xiàn)亂碼傳遞的,為了讓我們能看到顯示的亂碼,我們在對應(yīng)的Action類的子類里,修改一下,用System.out把接受到的參數(shù)輸出,代碼如下: Java代碼
http://58andy.sinaapp.com 1.public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, 2.HttpServletResponse response)...{ 3.DynaActionForm loginForm =(DynaActionForm)form;4.5.String username =(String)loginForm.get(“username”);6.String password =(String)loginForm.get(“password”);7.System.out.println(“username:”+username);8.System.out.println(“password:”+password);9.if(username.equals(“ivorytower”)&& password.equals(“123456”))...{ 10.return mapping.findForward(“success”);11.} 12.return mapping.findForward(“fail”);13.}
那么當(dāng)你提交了中文輸入后就會出現(xiàn)亂碼了。
具體的解決方法:
①修改Tomcat---->conf----->server.xml文件,在修改端口的標(biāo)簽后面加一行代碼,如下: Xml代碼
1. 3.redirectPort=“8443” URIEncoding=“UTF-8”/> ②編寫過濾器Filter Java代碼 1.2.import java.io.IOException;3.4.import javax.servlet.Filter;5.import javax.servlet.FilterChain;6.import javax.servlet.FilterConfig;7.import javax.servlet.ServletException;8.import javax.servlet.ServletRequest;9.import javax.servlet.ServletResponse;10.11.public class CharacterEncodingFilter implements Filter...{ http://58andy.sinaapp.com 12.13.@Override 14.public void destroy()...{ 15.} 16.17.@Override 18.public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException,ServletException { 19.request.setCharacterEncoding(“utf-8”);20.chain.doFilter(request, response);21.} 22.23.@Override 24.public void init(FilterConfig arg0)throws ServletException...{ 25.} 26.27.} 利用過濾器,把requst傳遞的中文參數(shù)都設(shè)成“UTF-8”編碼。 ③修改web.xml文件 打開項(xiàng)目里的web.xml文件,在前面加上如下代碼: Xml代碼 1.2. 3. 4. 6. 7. 注意其過濾的URL為“/*”,表示當(dāng)前的request請求。為了使設(shè)置生效,重起tomcat。 ㈢國際化資源文件亂碼 http://58andy.sinaapp.com ①利用JDK的native2ascii工具進(jìn)行編碼轉(zhuǎn)換 國際化問題,主要是為了處理文件在瀏覽器上的顯示問題,還是以登錄界面來說,比如在中文瀏覽器上,我們要看到中文顯示,對應(yīng)在英文瀏覽器上要顯示英文。那么我們在登錄那個界面處理上,就不能直接寫上我們的“用戶名”“密碼”等標(biāo)識了。就要用標(biāo)記轉(zhuǎn)換輸出了,修改為: Html代碼 1.2. 再者,打開項(xiàng)目下的資源配置文件ApplicationResources.properties,依據(jù)上面所寫key值,設(shè)定成我們要的默認(rèn)值(顯示英文),比如 引用 #Resource for Parameter 'com.v512.example.struts.ApplicationResources #Project webexample2 example.login.username=username example.login.password=password 現(xiàn)在我們動手新建一個資源文件,讓其能顯示中文,直接Ctrl+C,Ctrl+V。改名為ApplicationResources_zh.properties,代碼如下: 引用 #Resource for Parameter 'com.v512.example.struts.ApplicationResources #Project webexample2 example.login.username=用戶名 example.login.password=密碼 但保存,myeclipse會報錯,這時我們需要修改資源文件的編碼格式。Windons---->Preferences---->Content Type------>Text----->JavaPropertiesFile,把其Default encoding改為“utf-8”,按“update”更新。這樣就能進(jìn)行保存了。但是當(dāng)我們進(jìn)行驗(yàn)證會不是成功時,仍然給我們的是亂碼。 不急,我們還得做一項(xiàng)任務(wù),打開DOS窗口,CMD到資源文件所在目錄,運(yùn)用JDK的native2ascii工具把我們新建的資源文件改成另一個名字的資源文件,例如bank.properties。命令如下: 引用 >native2ascii-encoding gbk ApplicationResources_zh.properties bank.properties http://58andy.sinaapp.com 打開bank.properties資源文件,自動生成的代碼如下: 引用 #Generated by ResourceBundle Editor(http://eclipse-rbe.sourceforge.net) example.login.username = u7528u6237u540D example.login.password = u5BC6u7801 然后在myeclipse窗口中,把原來新建ApplicationResources_zh.properties 刪除,并把bank.properties改為ApplicationResources_zh.properties(為了方便記憶,管理)。然后重起tomcat或進(jìn)行reload文件,我們發(fā)現(xiàn)亂碼問題沒有了。 ②利用Eclipse ResourceBundle Editor插件工具 以上我們是利用了JDK的native2ascii工具來處理國際化問題,但在EC中,還有一種更方便的工具專門用來處理編輯java的資源文件國際化亂碼問題,即Eclipse ResourceBundle Editor插件工具。安裝了這個插件后,我們能進(jìn)行方便的可視化資源文件編輯。推薦。 問題1: 在使用tomcat服務(wù)器時,如在跳轉(zhuǎn)路徑中傳遞中文參數(shù)會出現(xiàn)亂碼現(xiàn)向!如:以 和第三篇:中文參數(shù)亂碼問題解決方案
解決:在tomcat/conf/servlet.Xml中 加入一段代碼:
debug=“0” connectionTimeout=“20000” disableUploadTimeout=“true” URIEncoding=“true”/> 問題2: 如果uri中轉(zhuǎn)遞的是參數(shù)要發(fā)送到j(luò)sp頁面,則必須在接受代碼的jsp頁面里面還要加入代碼: <% request.setCharacterEncoding(“gb2312”);%> 問題3: 在jsp頁面里的代碼修正: <%@ page language=“java” import=“java.util.*” pageEncoding=“gb2312”%> <%@ page contentType=“gb2312”%>