Если вы ищете способ его достижения без использования внешней библиотеки, вам поможет следующий код.
public static Map<String, String> splitQuery(URL url) throws UnsupportedEncodingException {
Map<String, String> query_pairs = new LinkedHashMap<String, String>();
String query = url.getQuery();
String[] pairs = query.split("&");
for (String pair : pairs) {
int idx = pair.indexOf("=");
query_pairs.put(URLDecoder.decode(pair.substring(0, idx), "UTF-8"), URLDecoder.decode(pair.substring(idx + 1), "UTF-8"));
}
return query_pairs;
}
Вы можете получить доступ к возвращенной карте с помощью <map>.get("client_id")
, с URL-адресом заданный в вашем вопросе, это вернет «SS».
UPDATE URL-декодирование добавлено
UPDATE. Поскольку этот ответ все еще довольно популярен, я сделал улучшенную версию вышеописанного метода, который
public static Map<String, List<String>> splitQuery(URL url) throws UnsupportedEncodingException {
final Map<String, List<String>> query_pairs = new LinkedHashMap<String, List<String>>();
final String[] pairs = url.getQuery().split("&");
for (String pair : pairs) {
final int idx = pair.indexOf("=");
final String key = idx > 0 ? URLDecoder.decode(pair.substring(0, idx), "UTF-8") : pair;
if (!query_pairs.containsKey(key)) {
query_pairs.put(key, new LinkedList<String>());
}
final String value = idx > 0 && pair.length() > idx + 1 ? URLDecoder.decode(pair.substring(idx + 1), "UTF-8") : null;
query_pairs.get(key).add(value);
}
return query_pairs;
}
UPDATE Версия Java8
public Map<String, List<String>> splitQuery(URL url) {
if (Strings.isNullOrEmpty(url.getQuery())) {
return Collections.emptyMap();
}
return Arrays.stream(url.getQuery().split("&"))
.map(this::splitQueryParameter)
.collect(Collectors.groupingBy(SimpleImmutableEntry::getKey, LinkedHashMap::new, mapping(Map.Entry::getValue, toList())));
}
public SimpleImmutableEntry<String, String> splitQueryParameter(String it) {
final int idx = it.indexOf("=");
final String key = idx > 0 ? it.substring(0, idx) : it;
final String value = idx > 0 && it.length() > idx + 1 ? it.substring(idx + 1) : null;
return new SimpleImmutableEntry<>(key, value);
}
Выполнение вышеуказанного метода с помощью URL
https://stackoverflow.com?param1=value1¶m2=¶m3=value3¶m3
возвращает эту карту:
{param1=["value1"], param2=[null], param3=["value3", null]}
Вы не можете использовать параметры в операторах SQL вместо идентификаторов (имена столбцов или таблиц). Вы можете использовать их только для одиночных значений .
Вместо этого вы должны использовать динамический SQL для построения всей строки SQL и отправить это, непараметризированное в базу данных (будучи дополнительным старайтесь избегать инъекций, если имя таблицы происходит вне вашего кода).
Вы не можете заменить метаданные в параметризованных запросах.