source: trunk/src/gcc/libjava/java/net/URLDecoder.java@ 154

Last change on this file since 154 was 2, checked in by bird, 23 years ago

Initial revision

  • Property cvs2svn:cvs-rev set to 1.1
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 5.6 KB
Line 
1/* URLDecoder.java -- Class to decode URL's from encoded form.
2 Copyright (C) 1998, 1999, 2000, 2001 Free Software Foundation, Inc.
3
4This file is part of GNU Classpath.
5
6GNU Classpath is free software; you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
8the Free Software Foundation; either version 2, or (at your option)
9any later version.
10
11GNU Classpath is distributed in the hope that it will be useful, but
12WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with GNU Classpath; see the file COPYING. If not, write to the
18Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
1902111-1307 USA.
20
21Linking this library statically or dynamically with other modules is
22making a combined work based on this library. Thus, the terms and
23conditions of the GNU General Public License cover the whole
24combination.
25
26As a special exception, the copyright holders of this library give you
27permission to link this library with independent modules to produce an
28executable, regardless of the license terms of these independent
29modules, and to copy and distribute the resulting executable under
30terms of your choice, provided that you also meet, for each linked
31independent module, the terms and conditions of the license of that
32module. An independent module is a module which is not derived from
33or based on this library. If you modify this library, you may extend
34this exception to your version of the library, but you are not
35obligated to do so. If you do not wish to do so, delete this
36exception statement from your version. */
37
38package java.net;
39
40import java.io.UnsupportedEncodingException;
41
42 /**
43 * This utility class contains static methods that converts a
44 * string encoded in the x-www-form-urlencoded format to the original
45 * text. The x-www-form-urlencoded format replaces certain disallowed
46 * characters with encoded equivalents. All upper case and lower case
47 * letters in the US alphabet remain as is, the space character (' ')
48 * is replaced with '+' sign, and all other characters are converted to a
49 * "%XX" format where XX is the hexadecimal representation of that character
50 * in a given character encoding (default is "UTF-8").
51 * <p>
52 * This method is very useful for decoding strings sent to CGI scripts
53 *
54 * Written using on-line Java Platform 1.2/1.4 API Specification.
55 * Status: Believed complete and correct.
56 *
57 * @since 1.2
58 *
59 * @author Warren Levy <[email protected]>
60 * @author Aaron M. Renn ([email protected]) (documentation comments)
61 * @author Mark Wielaard ([email protected])
62 */
63public class URLDecoder
64{
65 /**
66 * This method translates the passed in string from x-www-form-urlencoded
67 * format using the default encoding "UTF-8" to decode the hex encoded
68 * unsafe characters.
69 *
70 * @param s the String to convert
71 *
72 * @return the converted String
73 */
74 public static String decode(String s)
75 {
76 try
77 {
78 return decode(s, "UTF-8");
79 }
80 catch (UnsupportedEncodingException uee)
81 {
82 // Should never happen since UTF-8 encoding should always be supported
83 return s;
84 }
85 }
86
87 /**
88 * This method translates the passed in string from x-www-form-urlencoded
89 * format using the given character encoding to decode the hex encoded
90 * unsafe characters.
91 * <p>
92 * This implementation will decode the string even if it contains
93 * unsafe characters (characters that should have been encoded) or if the
94 * two characters following a % do not represent a hex encoded byte.
95 * In those cases the unsafe character or the % character will be added
96 * verbatim to the decoded result.
97 *
98 * @param s the String to convert
99 * @param encoding the character encoding to use the decode the hex encoded
100 * unsafe characters
101 *
102 * @return the converted String
103 *
104 * @since 1.4
105 */
106 public static String decode(String s, String encoding)
107 throws UnsupportedEncodingException