對于servlet大家應(yīng)該都很熟悉了,今天再復(fù)習(xí)一下,如果有哪里寫的不好或不對的地點(diǎn)希望廣大的網(wǎng)友批評指正。今天只討論get和post兩w種方式,他們之間有很多的不同點(diǎn),所以解決編碼的方式也會(huì)不一樣,post的亂碼問題好解決一點(diǎn),下面先簡單說下http協(xié)議,以便我能更好的記憶原理性的東西和他們之間的不同點(diǎn)。
get方式和post方式都是基于http協(xié)議的,它的目的是為了提供一種發(fā)布和接收html頁面的方法,由客戶端發(fā)起請求,服務(wù)器端進(jìn)行響應(yīng)。
一個(gè)完整的請求消息包括:一個(gè)請求行,若干消息頭和請求實(shí)體內(nèi)容
請求行包括請求方式(get或post), 資源路徑(要訪問的地址),http版本號(http1.1)
若干消息頭(比如包涵了瀏覽器的內(nèi)核信息(user-agent),打開它的父頁面是誰(refer)等
在請求實(shí)體內(nèi)容和消息頭中有一行空行,將消息頭和請求實(shí)體內(nèi)容分開,實(shí)體內(nèi)容有用戶提交的
一個(gè)完整的響應(yīng)消息包括:狀態(tài)行,一個(gè)或多個(gè)應(yīng)答頭,一個(gè)空行,響應(yīng)實(shí)體
狀態(tài)行:包括http協(xié)議版本號,狀態(tài)碼和原因敘述
常見狀態(tài)碼:200 正常
404:請求資源不存在
500:服務(wù)器內(nèi)部錯(cuò)誤
粗略說完http后可以介紹get和post方式的不同之處了
get方式:
get方式是將提交的內(nèi)容放到url的后面,長度有所限制,post和get都是基于http協(xié)議的,get方式是放到了請求行里,因?yàn)樗膮?shù)是在url中的,而post方式是放到請求實(shí)體內(nèi)容里的,post方式相對安全,瀏覽器不保留緩存信息,而get方式會(huì)wk保留緩存,可以從瀏覽器的歷史記錄里查看提交的內(nèi)容,并且get方式長度有限制,而post沒有。
正是因?yàn)間et方式和post方式提交數(shù)據(jù)時(shí)在http協(xié)議的位置不同,解決他們的編碼方式也會(huì)不同
post方式亂碼問題解決:
在servlet的service方法(doGet或doPost方法也可以)中,將request的編碼設(shè)置為UTF-8
1
|
req.setCharacterEncoding( "UTF-8" ); |
這樣,request的編碼就沒有問題了,然后將response的編碼也設(shè)置為UTF-8;
1
|
resp.setCharacterEncoding( "UTF-8" ); |
這樣,response的編碼也沒有問題了,但是這樣寫了以后到瀏覽器還是可能會(huì)出問題的,因?yàn)闉g覽器不知道你的編碼格式是什么,所以就按著瀏覽器的默認(rèn)格式來顯示,所以要把瀏覽器進(jìn)行顯示時(shí)的編碼方式也要設(shè)置為UTF-8,語句如下:
1
|
resp.setContextType( "text/html;charset=utf-8" ); |
同時(shí)還要保證你的開發(fā)工具編碼和項(xiàng)目的編碼一致,不然可能會(huì)出現(xiàn)亂碼問題,這里都是以UTF-8為例
get方式亂碼問題解決:
get方式除了上面的操作外還要在tomcat的conf目錄下的server.xml配置文件里面加上一句話,找到下面這句話,
1
2
3
|
<Connector port= "8080" protocol= "HTTP/1.1" connectionTimeout= "20000" redirectPort= "8443" /> |
修改后為
1
2
3
|
<Connector port= "8080" protocol= "HTTP/1.1" connectionTimeout= "20000" redirectPort= "8443" userBodyEncodingForURI= "true" /> |
這種改法比較靈活,讓URL的編碼格式跟著頁面的編碼格式一樣,也可以設(shè)置為固定的某一種格式,如
1
2
3
|
<Connector port= "8080" protocol= "HTTP/1.1" connectionTimeout= "20000" redirectPort= "8443" EncodingForURI= "UTF-8" /> |
這樣就基本上沒有什么問題了,如果還有問題,就得用String里的方法,將頁面的亂碼改為你想要的格式了,不過,如果上面的方式都對了,這種方式就不怎么會(huì)用到了。
除了上面的操作外,也要把數(shù)據(jù)庫的編碼格式設(shè)為與項(xiàng)目的一樣才行,這里就是改為UTF-8了,因?yàn)闀r(shí)間有限,所以寫的比較粗糙,還有很多東西也都給省略了,不過解決servlet的編碼方式應(yīng)該是夠了的。
調(diào)用時(shí)可以用js,如:
1
2
3
|
function ceshi() { window.location.href = "UserServlet?uname=zhangsan&realname=" + encodeURIComponent( "大家好" ); } |
這樣就將大家好就不會(huì)再顯示漢字到地址欄了(把這句話綁定到提交按扭上),就可以提交到相應(yīng)的servlet了。這種解決亂碼的方式同樣也適用于jsp
對了,還得再說點(diǎn)跟servlet有關(guān)系的,那就是forward和redirect,forward只能是在當(dāng)前項(xiàng)目進(jìn)行跳轉(zhuǎn),redirect可以跳轉(zhuǎn)到外面去,當(dāng)然,他們還有別的區(qū)別,這里我只說一點(diǎn)我覺得重要的東西,那就是無論使用哪一種,寫完了forward和redirect后,一定要加上return,如果不加,后面的語句還是會(huì)被執(zhí)行的,加上return后,后面的語句就會(huì)報(bào)錯(cuò),這樣就阻止了同一個(gè)頁面進(jìn)行了多次跳轉(zhuǎn)。不喜歡的網(wǎng)友誤噴,謝謝合作,感謝幫我挑錯(cuò)的網(wǎng)友,因?yàn)檫@樣我才會(huì)不斷進(jìn)步,真心感謝你們