日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java urlencode 解码_java.net.URLEncode编码 与 URLDecode解码问题

發布時間:2023/12/15 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java urlencode 解码_java.net.URLEncode编码 与 URLDecode解码问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

網頁中的表單使用POST方法提交時,數據內容的類型是 application/x-www-form-urlencoded,這種類型會:

1.字符"a"-"z","A"-"Z","0"-"9",".","-","*",和"_" 都不會被編碼;

2.將空格轉換為加號 (+) ;

3.將非文本內容轉換成"%xy"的形式,xy是兩位16進制的數值;

4.在每個 name=value 對之間放置 & 符號。

*/

URLEncoder類包含將字符串轉換為application/x-www-form-urlencoded MIME 格式的靜態方法。

web設計者面臨的眾多難題之一便是怎樣處理不同操作系統間的差異性。這些差異性能引起URL方面的問題:例如,一些操作系統允許文件名中含有空格符,有些又不允許。大多數操作系統不會認為文件名中含有符號“#”會有什么特殊含義;但是在一個URL中,符號“#”表示該文件名已經結束,后面會緊跟一個fragment(部分)標識符。其他的特殊字符,非字母數字字符集,它們在URL或另一個操作系統上都有其特殊的含義,表述著相似的問題。為了解決這些問題,我們在URL中使用的字符就必須是一個ASCII字符集的固定字集中的元素,具體如下:

1.大寫字母A-Z

2.小寫字母a-z

3.數字 0-9

4.標點符 - _ . ! ~ * ' (和 ,)

諸如字符: / & ? @ # ; $ + = 和 %也可以被使用,但是它們各有其特殊的用途,如果一個文件名包括了這些字符( / & ? @ # ; $ + = %),這些字符和所有其他字符就應該被編碼。

編碼過程非常簡單,任何字符只要不是ASCII碼數字,字母,或者前面提到的標點符,它們都將被轉換成字節形式,每個字節都寫成這種形式:一個“%”后面跟著兩位16進制的數值。空格是一個特殊情況,因為它們太平常了。它除了被編碼成“%20”以外,還能編碼為一個“+”。加號(+)本身被編碼為%2B。當/ # = & 和?作為名字的一部分來使用時,而不是作為URL部分之間的分隔符來使用時,它們都應該被編碼。

WARNING這種策略在存在大量字符集的異構環境中效果不甚理想。例如:在U.S. Windows 系統中, é 被編碼為 %E9. 在 U.S. Mac中被編碼為%8E。這種不確定性的存在是現存的URI的一個明顯的不足。所以在將來URI的規范當中應該通過國際資源標識符(IRIs)進行改善。

類URL并不自動執行編碼或解碼工作。你能生成一個URL對象,它可以包括非法的ASCII和非ASCII字符和/或%xx。當用方法getPath() 和toExternalForm( ) 作為輸出方法時,這種字符和轉移符不會自動編碼或解碼。你應對被用來生成一個URL對象的字符串對象負責,確保所有字符都會被恰當地編碼。

幸運的是,java提供了一個類URLEncoder把string編碼成這種形式。Java1.2增加了一個類URLDecoder它能以這種形式解碼string。這兩個類都不用初始化:

public class URLDecoder extends Object

public class URLEncoder extends Object

一、URLEncoder

在java1.3和早期版本中,類java.net.URLEncoder包括一個簡單的靜態方法encode( ), 它對string以如下規則進行編碼:

public static String encode(String s)

這個方法總是用它所在平臺的默認編碼形式,所以在不同系統上,它就會產生不同的結果。結果java1.4中,這個方法被另一種方法取代了。該方法要求你自己指定編碼形式:

public static String encode(String s, String encoding) throws UnsupportedEncodingException

兩種關于編碼的方法,都把任何非字母數字字符轉換成%xx(除了空格,下劃線(_),連字符(?),句號(。),和星號(*))。兩者也都編碼所以的非ASCII字符。空格被轉換成一個加號。這些方法有一點過分累贅了;它們也把“~”,“‘”,“()”轉換成%xx,即使它們完全用不著這樣做。盡管這樣,但是這種轉換并沒被URL規范所禁止。所以web瀏覽器會自然地處理這些被過分編碼后的URL。

兩中關于編碼的方法都返回一個新的被編碼后的string,java1.3的方法encode( ) 使用了平臺的默認編碼形式,得到%xx。這些編碼形式典型的有:在 U.S. Unix 系統上的ISO-8859-1, 在U.S. Windows 系統上的Cp1252,在U.S. Macs上的MacRoman,和其他本地字符集等。因為編碼解碼過程都是與本地操作平臺相關的,所以這些方法是令人不爽的,不能跨平臺的。

這就明確地回答了為什么在java1.4中這種方法被拋棄了,轉而投向了要求以自己指定編碼形式的這種方法。盡管如此,如果你執意要使用所在平臺的默認編碼形式,你的程序將會像在java1.3中的程序一樣,是本地平臺相關的。在另一種編碼的方法中,你應該總是用UTF-8,而不是其他什么。UTF-8比起你選的其他的編碼形式來說,它能與新的web瀏覽器和更多的其他軟件相兼容。

例子7-8是使用URLEncoder.encode( ) 來打印輸出各種被編碼后的string。它需要在java1.4或更新的版本中編譯和運行。

Example 7-8. x-www-form-urlencoded strings

import java.net.URLEncoder;

import java.net.URLDecoder;

import java.io.UnsupportedEncodingException;

public class EncoderTest {

public static void main(String[] args) {

try {

System.out.println(URLEncoder.encode("This string has spaces","UTF-8"));

System.out.println(URLEncoder.encode("This*string*has*asterisks","UTF-8"));

System.out.println(URLEncoder.encode("This%string%has%percent%signs", "UTF-8"));

System.out.println(URLEncoder.encode("This+string+has+pluses","UTF-8"));

System.out.println(URLEncoder.encode("This/string/has/slashes","UTF-8"));

System.out.println(URLEncoder.encode("This"string"has"quote"marks", "UTF-8"));

System.out.println(URLEncoder.encode("This:string:has:colons","UTF-8"));

System.out.println(URLEncoder.encode("This~string~has~tildes","UTF-8"));

System.out.println(URLEncoder.encode("This(string)has(parentheses)", "UTF-8"));

System.out.println(URLEncoder.encode("This.string.has.periods","UTF-8"));

System.out.println(URLEncoder.encode("This=string=has=equals=signs", "UTF-8"));

System.out.println(URLEncoder.encode("This&string&has&ersands","UTF-8"));

System.out.println(URLEncoder.encode("Thiséstringéhasé non-ASCII characters","UTF-8"));

// System.out.println(URLEncoder.encode("this中華人民共和國","UTF-8"));

} catch (UnsupportedEncodingException ex) {

throw new RuntimeException("Broken VM does not support UTF-8");

}

}

}

下面就是它的輸出。需要注意的是這些代碼應該以其他編碼形式被保存而不是以ASCII碼的形式,還有就是你選擇的編碼形式應該作為一個參數傳給編譯器,讓編譯器能據此對源代碼中的非ASCII字符作出正確的解釋。

% javac -encoding UTF8 EncoderTest %

java EncoderTest

This+string+has+spaces

This*string*has*asterisks

This%25string%25has%25percent%25signs

This%2Bstring%2Bhas%2Bpluses

This%2Fstring%2Fhas%2Fslashes

This%22string%22has%22quote%22marks

This%3Astring%3Ahas%3Acolons

This%7Estring%7Ehas%7Etildes

This%28string%29has%28parentheses%29

This.string.has.periods

This%3Dstring%3Dhas%3Dequals%3Dsigns

This%26string%26has%26ampersands

This%C3%A9string%C3%A9has%C3%A9non-ASCII+characters

特別需要注意的是這個方法編碼了符號,“\” ,&,=,和:。它不會嘗試著去規定在一個URL中這些字符怎樣被使用。由此,所以你不得不分塊編碼你的URL,而不是把整個URL一次傳給這個方法。這是很重要的,因為對類URLEncoder最通常的用法就是查詢string,為了和服務器端使用GET方法的程序進行交互。例如,假設你想編碼這個查詢sting,它用來搜索AltaVista網站:

pg=q&kl=XX&stype=stext&q=+"Java+I/O"&search.x=38&search.y=3

這段代碼對其進行編碼:

String query = URLEncoder.encode( "pg=q&kl=XX&stype=stext&q=+"Java+I/O"&search.x=38&search.y=3");System.out.println(query);

不幸的是,得到的輸出是:

pg%3Dq%26kl%3DXX%26stype%3Dstext%26q%3D%2B%22Java%2BI%2FO%22%26search.x%3D38%26search.y%3D3

出現這個問題就是方法URLEncoder.encode( ) 在進行盲目地編碼。它不能區分在URL或者查詢string中被用到的特殊字符(象前面string中的“=”,和“&”)和確實需要被編碼的字符。由此,所以URL需要像下面這樣一次只編碼一塊:

String query = URLEncoder.encode("pg");

query += "=";

query += URLEncoder.encode("q");

query += "&";

query += URLEncoder.encode("kl");

query += "=";

query += URLEncoder.encode("XX");

query += "&";

query += URLEncoder.encode("stype");

query += "=";

query += URLEncoder.encode("stext");

query += "&";

query += URLEncoder.encode("q");

query += "=";

query += URLEncoder.encode(""Java I/O"");

query += "&";

query += URLEncoder.encode("search.x");

query += "=";

query += URLEncoder.encode("38");

query += "&";

query += URLEncoder.encode("search.y");

query += "=";

query += URLEncoder.encode("3");

System.out.println(query);

這才是你真正想得到的輸出:

pg=q&kl=XX&stype=stext&q=%2B%22Java+I%2FO%22&search.x=38&search.y=3

例子7-9是一個QueryString類。在一個java對象中,它使用了類URLEncoder來編碼連續的屬性名和屬性值對,這個java對象被用來發送數據到服務器端的程序。

當你在創建一個QueryString對象時,你可以把查詢string中的第一個屬性對傳遞給類QueryString的構造函數,得到初始string。如果要繼續加入后面的屬性對,就應調用方法add(),它也能接受兩個string作為參數,能對它們進行編碼。方法getQuery( )返回一個屬性對被逐個編碼后得到的整個string。

Example 7-9. -The QueryString class

package com.tayh.otc.led.business;

import java.net.URLEncoder;

import java.io.UnsupportedEncodingException;

public class QueryString {

private final StringBuffer query = new StringBuffer();

public QueryString(final String name, final String value) {

encode(name, value);

}

public synchronized void add(final String name, final String value) {

query.append('&');

encode(name, value);

}

private synchronized void encode(final String name, final String value) {

try {

query.append(URLEncoder.encode(name, "UTF-8"));

query.append('=');

query.append(URLEncoder.encode(value, "UTF-8"));

} catch (UnsupportedEncodingException ex) {

throw new RuntimeException("Broken VM does not support UTF-8");

}

}

public String getQuery() {

return query.toString();

}

public String toString() {

return getQuery();

}

}

利用這個類,現在我們就能對前面那個例子中的string進行編碼了:

QueryString qs = new QueryString("pg", "q");

qs.add("kl", "XX");

qs.add("stype", "stext");

qs.add("q", "+"Java I/O"");

qs.add("search.x", "38");

qs.add("search.y", "3");

System.out.println(url);

二、URLDecoder

與URLEncoder 類相對應的URLDecoder 類有兩種靜態方法。它們解碼以x-www-form-url-encoded這種形式編碼的string。也就是說,它們把所有的加號(+)轉換成空格符,把所有的%xx分別轉換成與之相對應的字符:

public static String decode(String s) throws Exception  public static String decode(String s, String encoding) // Java 1.4 throws UnsupportedEncodingException

第一種解碼方法在java1.3和java1.2中使用。第二種解碼方法在java1.4和更新的版本中使用。如果你拿不定主意用哪種編碼方式,那就選擇UTF-8吧。它比其他任何的編碼形式更有可能得到正確的結果。

如果string包含了一個“%”,但緊跟其后的不是兩位16進制的數或者被解碼成非法序列,該方法就會拋出IllegalArgumentException 異常。當下次再出現這種情況時,它可能就不會被拋出了。這是與運行環境相關的,當檢查到有非法序列時,拋不拋出IllegalArgumentException 異常,這時到底會發生什么是不確定的。在Sun's JDK 1.4中,不會拋出什么異常,它會把一些莫名其妙的字節加進不能被順利編碼的string中。這的確令人頭疼,可能就是一個安全漏洞。

由于這個方法沒有觸及到非轉義字符,所以你可以把整個URL作為參數傳給該方法,不用像之前那樣分塊進行。

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的java urlencode 解码_java.net.URLEncode编码 与 URLDecode解码问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品电影在线观看 | 欧美日韩一区在线播放 | 久久免费激情视频 | 尤物在线 | 日韩成人区 | 狠狠a | 欧美一级特黄aa大片 | 日日夜夜婷婷 | 欧美一区二区三区激情视频 | 久久精品a亚洲国产v高清不卡 | 日本在线中文字幕专区 | 亚洲特级片 | 亚洲经典自拍 | 日本国产在线播放 | 日本老年老熟无码 | 中文字幕一区二区久久人妻网站 | 成人免费视频一区二区 | 永久免费看片在线观看 | 免费一级特黄特色毛片久久看 | 久久视频一区 | 懂色一区二区三区 | 日韩成人不卡 | k8经典成人理伦片 | 天堂一区在线 | 亚洲综合a| 日本高清视频一区 | 中文字幕在线观看日本 | 美女高潮视频在线观看 | 日韩精品国产一区二区 | wwxx日本| 天天爽夜夜爽人人爽 | 蜜桃又黄又粗又爽av免 | 国产久操视频 | 日本黄色免费大片 | 色欲无码人妻久久精品 | 国产精品自慰网站 | 人人干夜夜操 | 国产a网站 | 热热久| 亚洲精品电影院 | 在线xxxx | 亚洲暴爽| jizzzz中国| 草视频在线观看 | 美国免费黄色片 | 亚洲奶汁xxxx哺乳期 | 国产精品视频久久久久 | 日本久久网| 精品人妻一区二区三区久久嗨 | 国产v片| 亚洲欧洲国产日韩 | 91制服诱惑 | 亚洲天堂性 | 人人亚洲 | 亚洲AV第二区国产精品 | 99国产精品久久久久久久久久久 | 日本在线国产 | 超碰人人国产 | 国产欧美又粗又猛又爽 | 中文字幕有码在线 | 国产一二三四在线 | 91天堂在线观看 | 91精品国自产 | 精品久久中文 | 91麻豆视频网站 | 性一交一乱一色一免费无遮挡 | 国产网站黄 | 日韩毛片在线看 | 国产一区二区激情视频 | 国产精品丝袜 | 制服丝袜先锋 | 18岁免费观看电视连续剧 | 亚洲特黄毛片 | 亚欧成人精品一区二区 | 欧美国产高潮xxxx1819 | 国产精品久线在线观看 | 色综合天天综合网天天看片 | 亚洲视频国产 | 欧美亚洲第一区 | 成人在线免费av | 在线无 | 操操操网站 | 嫩草视频在线看 | 青草在线视频 | 色婷婷视频在线 | 极品久久久久久 | 久操这里只有精品 | 日本特黄视频 | 娇小萝被两个黑人用半米长 | www欧美| 久久先锋| 日韩在线观看视频一区 | 色先锋资源网 | 帮我拍拍漫画全集免费观看 | 亚洲人成人 | 干骚视频 | 欧美午夜精品理论片a级按摩 | 五月天综合婷婷 | 国产一区伦理 |