| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectcom.endeca.util.UrlBuilder
public class UrlBuilder
A generic toolkit for manipulating and generating URL query strings.
 UrlBuilder takes a query string in a constructor as the
 base query to work with. The toString method called
 immediately after the constructor will return the original input URL.
 The remove and add parameter methods are
 evaluated in order. This means that a remove parameter after an add
 parameter will delete the parameter you just added.
 
This toolkit attempts to preserve whatever input URL parameters are input to the system as long as they follow the structure of an ampersand (&) delimited, x-www-form-urlencoded parameter value pairs. In the case of multiple parameters with the same name, the multiple pairs will be preserved on output; however, a remove or add with the same name will remove or overwrite all keys with that name. An append, on the other hand, will preserve the previous parameters. An append adds parameters without affecting the previous parameter list. This class is taken somewhat wholesale from the old MDEX6 API jar (endeca-navigation.jar), renamed (from UrlBuilder), and fixed to use generics and java.net.UrlEncoder instead of the home grown encoder it used to use.
| Constructor Summary | |
|---|---|
| UrlBuilder(java.lang.String queryString,
           java.lang.String encoding)Constructor where the start URL will be the one specified in this constructor. | |
| Method Summary | |
|---|---|
|  void | addParam(java.lang.String key,
         java.lang.String value)Manipulates the resultant URL by adding this key/value pair. | 
|  void | addParams(java.util.Collection<java.lang.String> c)Bulk add of parameter key/value pairs. | 
|  void | appendParam(java.lang.String key,
            java.lang.String value)Manipulates the resultant URL by adding a key/value pair. | 
|  void | appendParams(java.util.Collection<java.lang.String> c)Bulk append of parameter key/value pairs. | 
|  java.lang.String | getBaseUrl() | 
|  void | removeParam(java.lang.String key)Removes any key/value parameter pair from the outputted URL. | 
|  void | removeParams(java.util.Collection<java.lang.String> c)Removes any key/value parameter with the keys specified in the collection. | 
|  void | setBaseUrl(java.lang.String baseUrl) | 
|  java.lang.String | toString()The output method on this class. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Constructor Detail | 
|---|
public UrlBuilder(java.lang.String queryString,
                  java.lang.String encoding)
UrlBuilder
 manipulates. The URL form is of a URL query string, which means
 everything in a URL after the ? character and of the form
 where the query is made up of key/value pairs delimited by the &
 character and each pair is delimited by the = character and the keys and values are
 x-www-form-urlencoded.
queryString - the base query string with which this class
                      manipulates.encoding - the character encoding in which the URL is encoded.| Method Detail | 
|---|
public void appendParam(java.lang.String key,
                        java.lang.String value)
value is decoded and will encode the value as
 x-www-form-urlencoded on output. Values that are null or equal
 to "" will be skipped so that this method can be
 called without having to check if the value is present.
key - key name of the pair to be added.value - the value to be added to the output URL where the value is
                decoded.public void appendParams(java.util.Collection<java.lang.String> c)
 (String)key=value
 appendParam method except that the
 values are encoded.
c - Collection of key/value pairs.
public void addParam(java.lang.String key,
                     java.lang.String value)
value is decoded and will encode the value as
 x-www-form-urlencoded on output. Values that are null or equal
 to "" will be skipped so that this method can be
 called without having to check if the value is present.
key - key name of the pair to be added.value - the value to be added to the output URL where the value is
                decoded.public void addParams(java.util.Collection<java.lang.String> c)
 (String)key=value
 addParam method except that the values are encoded.
c - Collection of key value pairs.public void removeParam(java.lang.String key)
addParam call.
 In the case of multiple parameters with the same
 name, this method will remove all pairs with the same name.
key - parameter pair to remove with the parameter name
              keypublic void removeParams(java.util.Collection<java.lang.String> c)
removeParam
 method except that it is batch-applied with the
 Collection c.  Each element of
 Collection c must be able to be casted as a String and be non-null.
public java.lang.String toString()
toString
 method will output a query string format of the input URL
 and subsequent add and remove calls.
 A call to this method does not invalidate the class but merely
 generates a snapshot output.
toString in class java.lang.Objectpublic void setBaseUrl(java.lang.String baseUrl)
public java.lang.String getBaseUrl()
| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||