久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

java - url解碼出錯

瀏覽:105日期:2023-10-27 13:20:44

問題描述

問題:安卓向后臺server發送的中文,解碼是亂碼。。

環境:

1. tomcat,在server.xml中已經明確了“utf-8'.2. 安卓已經明確了使用Utf-8編碼3. 在后臺使用` java.net.URLDecoder.decode(url, 'utf-8');`對url進行解碼,但是解碼出錯。。中文是”??“。

應該是編碼問題啊,,但是。。。

萬分感謝。。。

另外,我使用如下語句測試編碼:

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 里面的參數值,避免與 URL 格式本身發生沖突。Tomcat 會自動解碼 URL 參數值,所以你只需要直接獲取就好。例如下面這個 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://m.baoyu77737.com/wenda/?name=<%=URLEncoder.encode('你好', 'UTF-8')%>'>你好</a><a href='http://m.baoyu77737.com/wenda/?name=你好'>你好</a>

實際上兩個“你好”鏈接是沒有區別的,你可以打開網頁源代碼看到它們鏈接地址,一個有編碼一個沒有,但點擊之后,控制臺都能輸出正確的值,也就是說 request.getParameter('name') 得到的內容是完全一樣的。

標簽: java
相關文章:
主站蜘蛛池模板: 平舆县| 霍邱县| 虎林市| 剑河县| 保亭| 清水河县| 溧阳市| 颍上县| 广州市| 衡南县| 德阳市| 襄城县| 呼玛县| 安康市| 利川市| 望都县| 石泉县| 宁乡县| 康保县| 竹溪县| 巴林右旗| 惠来县| 松桃| 古田县| 察隅县| 吉木乃县| 洪泽县| 德昌县| 渝北区| 留坝县| 阜平县| 乌海市| 乾安县| 平和县| 全椒县| 敖汉旗| 固原市| 瑞丽市| 竹山县| 杭锦后旗| 拜泉县|