java - url解碼出錯
問題描述
問題:安卓向后臺server發(fā)送的中文,解碼是亂碼。。
環(huán)境:
1. tomcat,在server.xml中已經(jīng)明確了“utf-8'.2. 安卓已經(jīng)明確了使用Utf-8編碼3. 在后臺使用` java.net.URLDecoder.decode(url, 'utf-8');`對url進(jìn)行解碼,但是解碼出錯。。中文是”??“。
應(yīng)該是編碼問題啊,,但是。。。
萬分感謝。。。
另外,我使用如下語句測試編碼:
if (url.equals(new String(url.getBytes('iso8859-1'), 'iso8859-1'))) { url = new String(url.getBytes('iso8859-1'), 'utf-8'); System.out.println('ios8859-1');}if (url.equals(new String(url.getBytes('GB2312'), 'GB2312'))) { url = new String(url.getBytes('GB2312'), 'utf-8'); System.out.println('gb2312');}
輸出
ios8859-1gb2312
。。。。
問題解答
回答1:后臺的有沒有加入編碼過濾器?
回答2:URLEncode/Decode 是針對 URL 里面的參數(shù)值,避免與 URL 格式本身發(fā)生沖突。Tomcat 會自動解碼 URL 參數(shù)值,所以你只需要直接獲取就好。例如下面這個 JSP:
<%@ page import='java.net.URLEncoder' %><%@ page contentType='text/html;charset=UTF-8' language='java' %><% System.out.println('name=' + request.getParameter('name'));%><a href='http://www.lshqa.cn/wenda/?name=<%=URLEncoder.encode('你好', 'UTF-8')%>'>你好</a><a href='http://www.lshqa.cn/wenda/?name=你好'>你好</a>
實(shí)際上兩個“你好”鏈接是沒有區(qū)別的,你可以打開網(wǎng)頁源代碼看到它們鏈接地址,一個有編碼一個沒有,但點(diǎn)擊之后,控制臺都能輸出正確的值,也就是說 request.getParameter('name') 得到的內(nèi)容是完全一樣的。
相關(guān)文章:
1. python2.7 urllib2 獲取網(wǎng)頁顯示不全2. python - 調(diào)用api輸出頁面,會有標(biāo)簽出現(xiàn),請問如何清掉?3. mysql - 對單表大量數(shù)據(jù)進(jìn)行報表匯總有什么高效的方法4. mysql - 10g數(shù)據(jù)庫如何遷移5. python 匹配數(shù)據(jù)輸出數(shù)據(jù)6. python - 爬取微信公眾號文章需要輸入驗證碼問題7. node.js - session怎么存到cookie,然后服務(wù)器重啟后還能獲取。數(shù)據(jù)庫不用mongodb或redis,數(shù)據(jù)庫是mysql8. javascript - vue引入微信jssdk 配置在哪個生命周期調(diào)取接口配置?9. 數(shù)據(jù)庫設(shè)計 - 社交應(yīng)用的mysql表主鍵該怎么定義?10. python - django中找不到css等靜態(tài)文件
