var
?xml?
=
?GenXMLData(tableName,?fieldID,?
""
,?
""
);????
var
?content?
=
?
"
<
table?height=100%?width=100%><tr><td><div?id='divDoing'?style
='position:absolute;?left:500px;?top:136px;?width:196px;?height:105px;?z-
index:1;'><div?align='center'><p><img?src='../Images/doing.gif'?width
='32'?height='32'/></p><p><br/>正在查詢、請稍候……</p>
</div></div></td></tr></table>
"
;
????contentTD.innerHTML?
=
?content;
????????
var
?XmlHttp
=
new
?ActiveXObject(
"
Microsoft.XMLHTTP
"
);
????XmlHttp.onreadystatechange
=
function
()
{
???????
if
(XmlHttp.readyState
==
4
)
{
????????????
if
(XmlHttp.status
==
200
)
????????????
{
??????????????contentTD.innerHTML?
=
?XmlHttp.responseText;
??????????????firstPost?
=
?
true
;
????????????}
????????????
else
????????????contentTD.innerHTML?
=
?content?;
????????}
????}
????XmlHttp.open(
"
post
"
,webFile,
true
);
????XmlHttp.send(xml);
今天主要講解配置文件的代碼,我學習實例,喜歡從控制層出發,然后用到了哪些類或者JSP,再一一扯“蛋”扯出來。
當然,還是先看web.xml
|
?
|
<property?name="beanNames">?? ??
|
有人可能提出問題,為什么非得要放在service層,而不是dao層,應該說,事務管理有一個不成文的規定,盡量將問題放在上層處理。
然后每個類由SPRING來管理,并且autowire="byName"來尋找依賴注入的bean。
所有的xml文件都已經配置完了,其實最重要也是這個,XML文件將是框架的一個趨勢,掌握了它,其實你已經打開了這個框架的門。
2、文件的編碼
????? 文件編碼最常使用的有兩種:ANSI和UTF-8,光看名字估計你都可以猜到了,ANSI就是我們保存文件時使用的默認編碼,而UTF-8則需自己設置。對于編碼的改變,我使用的工具是NOTEPAD和ECLIPSE,NOTEPAD使用最簡單,只要打開文件后在另存為中選擇相應的編碼就行了,而且它對編碼的支持非常好;而在ECLIPSE中,只要稍微設置一下就行了,打開首選項,然后選擇:常規->內容類型(ContentType),在右邊選中你想改變保存編碼的文件類型,然后在下方的缺省編碼中改變其值,最后點擊更新(UPDATE)按鈕即可。
?
而在其它的編輯器中,默認保存的內容都是GB2312或者GBK(NOTEPAD中對應ANSI).而根據前面所說的UTF-8和GBK,GB2312等的編碼值是不同的這一點,可以知道,如果文件使用了UTF-8,那么字符編碼就必須使用UTF-8,否則編碼值的不同就可能造成亂碼。而這也就是為什么那么多的人使用了UTF-8編碼后還會產生亂碼的根本原因。(JS和JSP都是這個道理)
3、JSP,STRUTS等的中文亂碼解決方案?????其實解決的方法只有一個:
?request.setCharacterEncoding(encoding);
???方法只有一種,但處理方式就多種多樣了,初學者會在JSP頁面上直接使用,而有經驗的程序員會使用過濾器。而現在所要說的方法也是過濾器。這里以統一使用UTF-8作為編碼作為例子說明。具體過程就不多說了,網上有很多教程。偷懶一點的,到TOMCAT中復制就行了。在TOMCAT的目錄下的"webapps"jsp-examples"WEB-INF"classes"filters"找到SetCharacterEncodingFilter.java 這個類,放到你的程序中并配置好映射路徑。配置好后基本上你的亂碼問題就解決了。但要映射路徑中需要注意的就是不能使用 '*'
??<filter-mapping>
????<filter-name>Set?Character?Encoding</filter-name>
????<servlet-name>*</servlet-name>
??</filter-mapping>
像上面這樣配置的話(可能也是網上大多教程的做法,想當年也是害苦了我),可能你只有JSP的亂碼解決了,要解決STRUTS的亂碼需要映射 *.do 或者 servletActionName。然后在初始化參數中設置encoding的值就行了。
<init-param>
??????<param-name>encoding</param-name>
??????<param-value>UTF-8</param-value>
</init-param>
當然,最重要的是要記得根據前面所說的方法,改變你所使用的編輯器保存文件的編碼要與使用的字符編碼一致。
而在JSP內容中,還是使用如網上教程所說的那種技倆,在所有頁面的頁首加入:
<%@?page?language="java"?contentType="text/html;?charset=UTF-8"
????pageEncoding="UTF-8"%>
至此,相信JSP,ACTION都不太可能出現亂碼了。
4、資源文件的亂碼解決方案
????? 資源文件誰都知道是國際化支持不可或缺的一部分,如果資源文件都出現亂碼了那還了得?其實資源文件的亂碼是很好解決的,其原因也是因為使用了UTF-8做為JSP編碼后,沒有相應地改變資源文件的文件編碼造成的,所以只要對資源文件保存的編碼進行更正后,亂碼問題也就解決了。當然,你的中文要使用 native2ascii 命令進行正確的轉換。
5、調用JS時,JS內容亂碼的解決方案。
???? 其實JS的亂碼還是跟文件的編碼有關系的,如果JS中有中文的話,那JS文件保存的編碼就必須跟調用此JS的頁面編碼相同,否則,你的所有中文都要從JSP頁面傳給JS才會顯示正常。可以看出對于調用JS出現的亂碼是最容易解決的.
6、AJAX提交數據亂碼,返回數據亂碼的解決方案
???? 萬變不離其宗,AJAX的亂碼問題自然跟編碼有關了,其實很多人跟我一樣想到了對文件編碼進行設置,并且在接數據時設置了requet的編碼,在返回的數據時設置了response的編碼一切都以為會很順利,可是這一切都是徒勞無功的,討厭的亂碼再一次出現在你眼前。在你試了N多種方法,包括JS自身的escape,unescape方法后,你發現亂碼仍然猖狂地出現在屏幕上。
??? 其實在試過這N多方法后,很多人都沒發現,解決的方法其實很簡單,而且其答案就在我們之前處理的JSP亂碼之中。讓我們先看一下AJAX的經典請求代碼
xmlhttp.open(?"post",?url,?async?);
xmlhttp.setRequestHeader(?"Content-Type",?"text/html"?);
xmlhttp.send(?params?);
通過前面的說明,不知道你現在看出端倪了沒有。不知道是受了網上教程的影響還是其它方面影響,setRequestHeader并是萬年不變的,也沒人想過去改它,而問題就正好出在這個地方。回想一個JSP頁面內容的編碼設置,其中有這么一節:
contentType="text/html;?charset=UTF-8"
現在知道問題了吧,所以我們要把第二句代碼改為:
xmlhttp.setRequestHeader(?"Content-Type",?"text/html;charset=UTF-8"?);
最后別忘了在返回數據時也設置上:
response.setContentType(?"text/xml"?);
response.setCharacterEncoding(?"UTF-8"?);
如果要問為什么的話,其實我們可以把xmlhttp看成是一個臨時頁面,它由瀏覽器動態生成,主要作用是在后臺獲得請求的數據(可以看成是一個高級的iframe)。所以對于普通頁面設置的編碼,對它也要同樣設置。而在servlet中返回數據為什么要設置contentType和encoding其道理也是一樣的。眾所周知,jsp的最后形態就是servlet,而jsp頁首設置的那個內容其實也就是讓生成的servlet中生成這么兩句話:
response.setContentType(?"text/html"?);
response.setCharacterEncoding(?"UTF-8"?);
而pageEncoding則是跟jvm說明了這個頁面的內容要使用什么編碼保存(這跟之后生成的CLASS有關系)。所以在servlet設置response的編碼也是理所當然的了。?
response.setContentType("text/xml;charset=UTF-8");
response.setHeader("Pragma",?? "no-cache");?? //HTTP?? 1.0??
response.setDateHeader("Expires",?? 0);?? //prevents?? caching?? at?? the?? proxy?? server??
PrintWriter out = response.getWriter();
out.write(outXML);
out.flush();
out.close();
OK!這樣向客戶端寫的數據中的中文也是UTF-8編碼了,客戶端js腳本獲取到request.responseXML也好,responseText也好,里面的數據都不會有亂碼了