通过js encodeURIComponent传到服务器的乱码问题
一、場景:最近在做一個微博項目,用過微博的人都知道,微博里有話題這個概念,在textarea 里輸入##,就代表一個話題。發布微博時使用的ajax方式提交,微博內容會拼到URI中傳到服務器端,發現用IE8輸入沒有任何問題,但是使用IE6時,第二個#號會丟失。
?
二、解決過程:(1) 在JSP中使用encodeURIComponent來進行編碼,兩次編碼:
?????
content=encodeURIComponent(encodeURIComponent(content)); var url="${pageContext.request.contextPath}/BlogAction.do?method=doPublishBlog&content="+content;??? (2) 在action中使用解碼:
String content=(String)request.getParameter("content"); content=URLDecoder.decode(content,"UTF-8");???這個問題得以解決。
?
三、擴展學習
?? (1)js 中encodeURI 與 encodeURIComponent的區別
encodeURI 方法返回一個編碼的 URI。如果您將編碼結果傳遞給 decodeURI,那么將返回初始的字符串。encodeURI 方法不會對下列字符進行編碼:":"、"/"、";" 和 "?"。請使用 encodeURIComponent 方法對這些字符進行編碼。經過我測試“#”也屬于這個特殊字符的范疇,使用encodeURI編碼時#是不會被編碼的,所以上面場景的問題依然存在的,對于這種輸入的內容,肯定是用encodeURIComponent。
?
??? (2)IE對#的不同處理,從下面的header 內容可以看出來。
IE8:
POST /dcwb/BlogAction.do?method=doPublishBlog&content=%23���?���%23&decorator=exclude&gridId=&gridName=&videoId=&imageId=&topicId=
?
?IE6:
POST /dcwb/BlogAction.do?method=doPublishBlog&content=%23��������%20&decorator=exclude&gridId=&gridName=&videoId=&imageId=&topicId= HTTP/1.1
總結
以上是生活随笔為你收集整理的通过js encodeURIComponent传到服务器的乱码问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java全半角转换
- 下一篇: freemarker元素的属性为空