HADOOP-12711. Remove dependency on commons-httpclient for ServletUtil (Wei-Chiu Chuang via iwasakims)
This commit is contained in:
parent
872b8d90a6
commit
b0091338f2
|
@ -501,6 +501,9 @@ Release 2.8.0 - UNRELEASED
|
||||||
HADOOP-12824. Collect network and disk usage on the node running Windows.
|
HADOOP-12824. Collect network and disk usage on the node running Windows.
|
||||||
(Inigo Goiri via xyao)
|
(Inigo Goiri via xyao)
|
||||||
|
|
||||||
|
HADOOP-12711. Remove dependency on commons-httpclient for ServletUtil
|
||||||
|
(Wei-Chiu Chuang via iwasakims)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
HADOOP-11785. Reduce the number of listStatus operation in distcp
|
HADOOP-11785. Reduce the number of listStatus operation in distcp
|
||||||
|
|
|
@ -17,18 +17,22 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.util;
|
package org.apache.hadoop.util;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.IOException;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
|
import java.net.URI;
|
||||||
|
import java.net.URISyntaxException;
|
||||||
|
import java.net.URLEncoder;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
|
|
||||||
import javax.servlet.*;
|
import javax.servlet.*;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
|
||||||
import org.apache.commons.httpclient.URIException;
|
|
||||||
import org.apache.commons.httpclient.util.URIUtil;
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.classification.InterfaceStability;
|
import org.apache.hadoop.classification.InterfaceStability;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
|
import org.apache.http.client.utils.URIBuilder;
|
||||||
|
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
@InterfaceStability.Unstable
|
@InterfaceStability.Unstable
|
||||||
|
@ -94,9 +98,10 @@ public class ServletUtil {
|
||||||
*/
|
*/
|
||||||
public static String encodeQueryValue(final String value) {
|
public static String encodeQueryValue(final String value) {
|
||||||
try {
|
try {
|
||||||
return URIUtil.encodeWithinQuery(value, "UTF-8");
|
return URLEncoder.encode(value, "UTF-8");
|
||||||
} catch (URIException e) {
|
} catch (UnsupportedEncodingException e) {
|
||||||
throw new AssertionError("JVM does not support UTF-8"); // should never happen!
|
throw new AssertionError("Failed to encode query value in UTF-8: " +
|
||||||
|
value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,11 +111,7 @@ public class ServletUtil {
|
||||||
* @return encoded path, null if UTF-8 is not supported
|
* @return encoded path, null if UTF-8 is not supported
|
||||||
*/
|
*/
|
||||||
public static String encodePath(final String path) {
|
public static String encodePath(final String path) {
|
||||||
try {
|
return new URIBuilder().setPath(path).toString();
|
||||||
return URIUtil.encodePath(path, "UTF-8");
|
|
||||||
} catch (URIException e) {
|
|
||||||
throw new AssertionError("JVM does not support UTF-8"); // should never happen!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -119,11 +120,14 @@ public class ServletUtil {
|
||||||
* @param servletName the name of servlet that precedes the path
|
* @param servletName the name of servlet that precedes the path
|
||||||
* @return decoded path component, null if UTF-8 is not supported
|
* @return decoded path component, null if UTF-8 is not supported
|
||||||
*/
|
*/
|
||||||
public static String getDecodedPath(final HttpServletRequest request, String servletName) {
|
public static String getDecodedPath(final HttpServletRequest request,
|
||||||
|
String servletName) {
|
||||||
|
String requestURI = request.getRequestURI();
|
||||||
|
String uriPath = getRawPath(request, servletName);
|
||||||
try {
|
try {
|
||||||
return URIUtil.decode(getRawPath(request, servletName), "UTF-8");
|
return new URI(uriPath).getPath();
|
||||||
} catch (URIException e) {
|
} catch (URISyntaxException e) {
|
||||||
throw new AssertionError("JVM does not support UTF-8"); // should never happen!
|
throw new AssertionError("Failed to decode URI: " + requestURI);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue