java - url解碼出錯(cuò)
問(wèn)題描述
問(wèn)題:安卓向后臺(tái)server發(fā)送的中文,解碼是亂碼。。
環(huán)境:
1. tomcat,在server.xml中已經(jīng)明確了“utf-8'.2. 安卓已經(jīng)明確了使用Utf-8編碼3. 在后臺(tái)使用` java.net.URLDecoder.decode(url, 'utf-8');`對(duì)url進(jìn)行解碼,但是解碼出錯(cuò)。。中文是”??“。
應(yīng)該是編碼問(wèn)題啊,,但是。。。
萬(wàn)分感謝。。。
另外,我使用如下語(yǔ)句測(cè)試編碼:
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
。。。。
問(wèn)題解答
回答1:后臺(tái)的有沒(méi)有加入編碼過(guò)濾器?
回答2:URLEncode/Decode 是針對(duì) URL 里面的參數(shù)值,避免與 URL 格式本身發(fā)生沖突。Tomcat 會(huì)自動(dòng)解碼 URL 參數(shù)值,所以你只需要直接獲取就好。例如下面這個(gè) 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.aoyou183.cn/wenda/?name=<%=URLEncoder.encode('你好', 'UTF-8')%>'>你好</a><a href='http://www.aoyou183.cn/wenda/?name=你好'>你好</a>
實(shí)際上兩個(gè)“你好”鏈接是沒(méi)有區(qū)別的,你可以打開(kāi)網(wǎng)頁(yè)源代碼看到它們鏈接地址,一個(gè)有編碼一個(gè)沒(méi)有,但點(diǎn)擊之后,控制臺(tái)都能輸出正確的值,也就是說(shuō) request.getParameter('name') 得到的內(nèi)容是完全一樣的。
相關(guān)文章:
1. javascript - npm下載的模塊不完整是什么問(wèn)題?2. java - Spring事務(wù)回滾問(wèn)題3. apache - 本地搭建wordpress權(quán)限問(wèn)題4. c++ - 如何在python的阻塞的函數(shù)中獲取變量值5. node.js - 我想讓最后進(jìn)入數(shù)據(jù)庫(kù)的數(shù)據(jù),在前臺(tái)最先展示,如何做到?6. wordpress - Nginx中禁止訪(fǎng)問(wèn)txt,robots.txt文件例外,規(guī)則該怎么寫(xiě)?7. 剛放到服務(wù)器的項(xiàng)目出現(xiàn)這中錯(cuò)誤,有高手指點(diǎn)嗎8. python - django 按日歸檔統(tǒng)計(jì)訂單求解9. python 操作mysql如何經(jīng)量防止自己的程序在之后被惡意注入(說(shuō)白了就是問(wèn)一下python防注入的一些要點(diǎn))10. mysql - 面試題:如何把login_log表轉(zhuǎn)換成last_login表?
