Спецификация gcc spec может выполнять задание, однако все пользователи на машине будут затронуты.
См. здесь
Это не имеет ничего общего с кодировками символов, такими как UTF-8 или ASCII. У вас есть строка URL, закодированная .
Попробуйте что-то вроде этого:
String result = java.net.URLDecoder.decode(url, "UTF-8");
Обратите внимание, что кодировка символа (например, UTF -8 или ASCII) - это то, что определяет отображение символов в сырые байты. Для хорошего ввода символов кодировки см. в этой статье .
У вас есть строка application/x-www-form-urlencoded
.
Используйте URLDecoder , чтобы преобразовать ее в строку Java.
URLDecoder.decode( url, "UTF-8" );
Это было отвечено перед (хотя этот вопрос был первым!):
«Вы должны использовать java.net.URI для этого, поскольку URLDecoder класс выполняет декодирование x-www-form-urlencoded, которое является неправильным (несмотря на имя, это данные формы). "
blockquote>В основном:
String url = "https%3A%2F%2Fmywebsite%2Fdocs%2Fenglish%2Fsite%2Fmybook.do%3Frequest_type"; System.out.println(new java.net.URI(url).getPath());
даст вы:
https://mywebsite/docs/english/site/mybook.do?request_type
%3A
и %2F
являются символами с кодировкой URL. Используйте этот Java-код, чтобы преобразовать их обратно в :
и /
String decoded = java.net.URLDecoder.decode(url, "UTF-8");
try {
String result = URLDecoder.decode(urlString, "UTF-8");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
URLDecoder.decode
один раз будет недостаточно. Например:
Поскольку один и тот же URL-адрес может быть закодирован несколько раз, нам нужно его декодировать пока URL-адрес не может быть расшифрован дальше. Например, «video% 252Fmp4» является результатом двух кодировок. После его декодирования один раз мы получаем «видео% 2Fmp4». Теперь URL-адрес должен быть дополнительно декодирован, чтобы мы получили «video / mp4», что является результатом.
blockquote>Вот код, который работает для всех таких случаев:
public static String decode(String url) { try { String prevURL=""; String decodeURL=url; while(!prevURL.equals(decodeURL)) { prevURL=decodeURL; decodeURL=URLDecoder.decode( decodeURL, "UTF-8" ); } return decodeURL; } catch (UnsupportedEncodingException e) { return "Issue while decoding" +e.getMessage(); } }
import java.io.UnsupportedEncodingException;
import java.net.URISyntaxException;
public class URLDecoding {
String decoded = "";
public String decodeMethod(String url) throws UnsupportedEncodingException
{
decoded = java.net.URLDecoder.decode(url, "UTF-8");
return decoded;
//"You should use java.net.URI to do this, as the URLDecoder class does x-www-form-urlencoded decoding which is wrong (despite the name, it's for form data)."
}
public String getPathMethod(String url) throws URISyntaxException
{
decoded = new java.net.URI(url).getPath();
return decoded;
}
public static void main(String[] args) throws UnsupportedEncodingException, URISyntaxException
{
System.out.println(" Here is your Decoded url with decode method : "+ new URLDecoding().decodeMethod("https%3A%2F%2Fmywebsite%2Fdocs%2Fenglish%2Fsite%2Fmybook.do%3Frequest_type"));
System.out.println("Here is your Decoded url with getPath method : "+ new URLDecoding().getPathMethod("https%3A%2F%2Fmywebsite%2Fdocs%2Fenglish%2Fsite%2Fmybook.do%3Frequest"));
}
}
Вы можете разумно выбрать свой метод :)
public String decodeString(String URL)
{
String urlString="";
try {
urlString = URLDecoder.decode(URL,"UTF-8");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
}
return urlString;
}
Я использую общедоступность apache
String decodedUrl = new URLCodec().decode(url);
Кодировка по умолчанию - UTF-8