類URLEncoder 和 類URLDecoder
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字符??崭癖晦D換成一個加號。這些方法有一點過分累贅了;它們—也把“~”,“‘”,“()”轉換成%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.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"));
}
catch (UnsupportedEncodingException ex) {
throw new RuntimeException("Broken VM does not support UTF-8");
}
}
}
新聞熱點
疑難解答