java中的url 編碼與解碼
% 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.macfaq.net;
import java.net.URLEncoder;
import java.io.UnsupportedEncodingException;
public class QueryString {
private StringBuffer query = new StringBuffer();
public QueryString(String name, String value) {
encode(name, value);
}
public synchronized void add(String name, String value) {
query.append('&');
encode(name, value);
}
private synchronized void encode(String name, 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");
String url = "
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作為引數傳給該方法,不用像之前那樣分塊進行。例如:
String input = "
try {
String output = URLDecoder.decode(input, "UTF-8");
System.out.println(output);
}
相關推薦
java中的url 編碼與解碼
下面就是它的輸出。需要注意的是這些程式碼應該以其他編碼形式被儲存而不是以ASCII碼的形式,還有就是你選擇的編碼形式應該作為一個引數傳給編譯器,讓編譯器能據此對原始碼中的非ASCII字元作出正確的解釋。 % javac -encoding UTF8 EncoderTest % java Enco
python接口自動化測試十三:url編碼與解碼
str 技術 bsp key 接口自動化測試 info pytho print 自動化測試 # url編碼與解碼 from urllib import parse url = ‘http://zzk.cnblogs.com/s/blogpost?Keywords=中文‘ a
js對url編碼與解碼
在前端工作中,偶爾會遇到url的編碼與解碼,比如:在微信授權登入的時候,需要將url進行編碼寫入,再比如:在PC端顯示小表情的時候,會用到對url解碼解析表情。那麼,有哪些編碼解碼方式呢,常用的是哪些呢? 1.為什麼要URL編碼 在因特網上傳送URL,只能採用
Python 中的編碼與解碼
Python2.x 和 Python3.x 中關於字元編碼的問題 1. 一些基本的概念 2. 編碼格式 3. 編碼和解碼 4. Python3 的預設編碼
Url編碼與解碼
package charset;import java.io.UnsupportedEncodingException;import org.apache.commons.codec.CharEncod
處理URL編碼與解碼
Python url編碼: urllib.quote(url)#沒有對“/”進行處理 urllib.quote_plus(url) url解碼: urllib.unquote(url)#
Web開發須知:URL編碼與解碼
通常如果一樣東西需要編碼,說明這樣東西並不適合傳輸。原因多種多樣,如Size過大,包含隱私資料,對於Url來說,之所以要進行編碼,是因為Url中有些字元會引起歧義。 例如,Url引數字串中使用key=value鍵值對這樣的形式來傳參,鍵值對之間以&符號分隔,如/s?q=abc& ie=u
URL編碼與解碼原理
通常如果一樣東西需要編碼,說明這樣東西並不適合傳輸。原因多種多樣,如Size過大,包含隱私資料,對於Url來說,之所以要進行編碼,是因為Url中有些字元會引起歧義。 例如,Url引數字串中使用key=value鍵值對這樣的形式來傳參,鍵值對之間以&
mysql中Base64編碼與解碼
在mysql中,有些資料我們不想讓別人直觀的看到,這時可以使用Base編碼與解碼。 mysql提供了相關的函式支援。 1、to_base64 編碼 如: select to_base64('12345'); 2、from_base64 解碼 如:select from_
URL編碼與解碼(使用 Python3 urllib.parse) 與 貼吧小爬蟲案例
parse 頁碼 這樣的 5.0 put 傳遞 range 通過 組合 一.parse.urlencode() 與parse.unquote() urllib 和urllib.request都是接受URL請求的相關模塊,但是提供了不同的功能。兩個最顯著的不同如下: 1.ur
簡訊中的的 UCS2的編碼與解碼方法(java)
最近,做一個關於SMS的程式,需要對中文部分進行UCS編碼,這裡用了兩個函式,可以將簡訊中的UCS2字串在UCS2和GBK之間裝換。記錄以下程式碼: /** * UCS2解碼 * * @param src *
Java-IO流之轉換流的使用和編碼與解碼原理
鍵盤輸入 tostring delet 特點 rgb utf8 equals pri 數據 一、理論: 1、字符流和字節流區別是什麽? 字符流=字節流+編碼集,在實際讀取的時候其實字符流還是按照字節來讀取,但是會更具編碼集進行查找編碼集字典解析相應的字節,使得一次讀取出一個
Python3中字符串的編碼與解碼以及編碼之間轉換(decode、encode)
python3 encode 由於 表示 nic code .... 以及 mage 一、編碼 二、編碼與解碼 Python3中對py文件的默認編碼是urf-8。但是字符串的編碼是Unicode。 由於Unicode采用32位4個字節來表示一個字符,存儲和傳輸太浪費資
python2與python3中編碼與解碼的區別
需要 顯示 數據類型 在屏幕上 nbsp gb2312 python2 想要 區別 python2中程序默認數據類型為ASCII, 所以需要先將數據解碼(decode)成為Unicode類型, 然後再編碼(encode)成為想要轉換的數據類型(gbk,utf-8,gb180
PHP和javascript中url編碼解碼詳解
http 遇到 註意 spa color 空格 www. col test 在實際開發中,我們可能會遇到路徑編碼解碼的問題,下面總結了一下: PHP中: 1、urlencode(編碼),urldecode(解碼) $a = urlencode(‘http://www.
java編碼與解碼(一)
轉:https://blog.csdn.net/heyanxi0101/article/details/80356870 java編碼與解碼(一) 編碼表概述和常見的編碼表 概述:有字元及其對應的數值組成的一張表 常見的編碼表 ASCII:美國標準資訊交換表ISO8859-1:拉丁碼
GET請求中關於中文的編碼與解碼
問:有時候在特殊情況下,需要使用GET請求來傳遞引數,而傳遞的引數中有中文字元。如何直接傳遞過去,會導致亂碼問題,針對這個情況如何解決? 原因:在使用get請求傳遞引數時,需要依賴瀏覽器環境,由於我們在javascript中沒有做任何操作,完全依賴瀏覽器進行編碼後傳遞到後臺,一旦於後臺編碼格式不
JS 和 Java 中URL特殊字元編碼方式
JavaScript 1. 編碼 escape(String) 其中某些字元被替換成了十六進位制的轉義序列。 解碼 unescape(String) 該函式的工作原理是這樣的:通過找到形式為 %xx 和 %uxxxx 的字元序列(x
JAVA中url的特殊字元處理及url轉碼解碼
在url中 , 只能使用url合法的字元 . 如果使用了非法字元來訪問某資源(如:+#等) , 就會導致資源訪問異常或失敗 . 同時原生url中也是不支援中文的 , 以百度為例 , 當你搜索了中文關鍵詞時 , 可以在url位址列中明顯的看出來中文被"編碼轉換了" . 本章暫
python3中編碼與解碼之Unicode與bytes
今天玩Python爬蟲,下載一個網頁,然後把所有內容寫入一個txt檔案中,出現錯誤;TypeError: write() argument must be str, not bytesAttributeError: 'URLError' object has no attri