com.norconex.commons.lang.url.QueryString Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of norconex-commons-lang Show documentation
Show all versions of norconex-commons-lang Show documentation
Norconex Commons Lang is a Java library containing utility classes that complements the Java API and are not found in commonly available libraries (such as the great Apache Commons Lang, which it relies on).
/* Copyright 2010-2015 Norconex Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.norconex.commons.lang.url;
import java.io.UnsupportedEncodingException;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.util.List;
import org.apache.commons.collections4.map.ListOrderedMap;
import org.apache.commons.lang3.CharEncoding;
import org.apache.commons.lang3.StringUtils;
import com.norconex.commons.lang.map.Properties;
/**
* Provides utility methods for getting and setting attributes on
* a URL query string.
*
* Since 1.4, query string parameters are stored and returned in the
* order they were provided.
* @author Pascal Essiembre
*/
@SuppressWarnings("nls")
public class QueryString extends Properties {
private static final long serialVersionUID = 1744232652147275170L;
private final String encoding;
/**
* Constructor.
*/
public QueryString() {
this(CharEncoding.UTF_8);
}
/**
* Default URL character encoding is UTF-8.
* @param urlWithQueryString a URL from which to extract a query string.
*/
public QueryString(URL urlWithQueryString) {
this(urlWithQueryString.toString(), null);
}
/**
* Constructor.
* @param urlWithQueryString a URL from which to extract a query string.
* @param encoding character encoding
*/
public QueryString(URL urlWithQueryString, String encoding) {
this(urlWithQueryString.toString(), encoding);
}
/**
* Constructor. Default URL character encoding is UTF-8.
* It is possible to only supply a query string as opposed to an
* entire URL.
* Key and values making up a query string are assumed to be URL-encoded.
* Will throw a {@link URLException} if UTF-8 encoding is not supported.
* @param urlWithQueryString a URL from which to extract a query string.
*/
public QueryString(String urlWithQueryString) {
this(urlWithQueryString, null);
}
/**
* Constructor.
* It is possible to only supply a query string as opposed to an
* entire URL.
* Key and values making up a query string are assumed to be URL-encoded.
* Will throw a {@link URLException} if the supplied encoding is
* unsupported or invalid.
* @param urlWithQueryString a URL from which to extract a query string.
* @param encoding character encoding
*/
public QueryString(String urlWithQueryString, String encoding) {
super(new ListOrderedMap>());
if (StringUtils.isBlank(encoding)) {
this.encoding = CharEncoding.UTF_8;
} else {
this.encoding = encoding;
}
String paramString = urlWithQueryString;
if (StringUtils.contains(paramString, "?")) {
paramString = paramString.replaceAll("(.*?)(\\?)(.*)", "$3");
}
String[] paramParts = paramString.split("\\&");
for (int i = 0; i < paramParts.length; i++) {
String paramPart = paramParts[i];
String key;
String value;
if (StringUtils.contains(paramPart, "=")) {
key = StringUtils.substringBefore(paramPart, "=");
value = StringUtils.substringAfter(paramPart, "=");
} else {
key = paramPart;
value = StringUtils.EMPTY;
}
try {
addString(URLDecoder.decode(key, this.encoding),
URLDecoder.decode(value, this.encoding));
} catch (UnsupportedEncodingException e) {
throw new URLException(
"Cannot URL-decode query string (key="
+ key + "; value=" + value + ").", e);
}
}
}
/**
* Gets the character encoding. Default is UTF-8.
* @return character encoding
* @since 1.7.0
*/
public String getEncoding() {
return encoding;
}
/**
* Convert this QueryString
to a URL-encoded string
* representation that can be appended as is to a URL with no query string.
*/
@Override
public synchronized String toString() {
if (isEmpty()) {
return "";
}
StringBuilder b = new StringBuilder();
char sep = '?';
for (String key : keySet()) {
for (String value : getStrings(key)) {
b.append(sep);
sep = '&';
try {
b.append(URLEncoder.encode(key, encoding));
b.append('=');
b.append(URLEncoder.encode(value, encoding));
} catch (UnsupportedEncodingException e) {
throw new URLException(
"Cannot URL-encode query string (key="
+ key + "; value=" + value + ").", e);
}
}
}
return b.toString();
}
/**
* Apply this url QueryString on the given URL. If a query string already
* exists, it is replaced by this one.
* @param url the URL to apply this query string.
* @return url with query string added
*/
public String applyOnURL(String url) {
if (StringUtils.isBlank(url)) {
return url;
}
return StringUtils.substringBefore(url, "?") + toString();
}
/**
* Apply this url QueryString on the given URL. If a query string already
* exists, it is replaced by this one.
* @param url the URL to apply this query string.
* @return url with query string added
*/
public URL applyOnURL(URL url) {
if (url == null) {
return url;
}
try {
return new URL(applyOnURL(url.toString()));
} catch (MalformedURLException e) {
throw new URLException("Cannot applyl query string to: " + url, e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy