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

Last change on this file since 192 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
108 {
109 StringBuffer result = new StringBuffer();
110
111 // First convert all '+' characters to spaces.
112 String str = s.replace('+', ' ');
113
114 // Then go through the whole string looking for byte encoded characters
115 int i;
116 int start = 0;
117 byte[] bytes = null;
118 int length = str.length();
119 while ((i = str.indexOf('%', start)) >= 0)
120 {
121 // Add all non-encoded characters to the result buffer
122 result.append(str.substring(start, i));
123 start = i;
124
125 // Get all consecutive encoded bytes
126 while ((i+2 < length) && (str.charAt(i) == '%'))
127 i += 3;
128
129 // Decode all these bytes
130 if ((bytes == null) || (bytes.length < ((i-start)/3)))
131 bytes = new byte[((i-start)/3)];
132
133 int index = 0;
134 try
135 {
136 while (start < i)
137 {
138 String sub = str.substring(start + 1, start + 3);
139 bytes[index] = (byte)Integer.parseInt(sub, 16);
140 index++;
141 start += 3;
142 }
143 }
144 catch (NumberFormatException nfe)
145 {
146 // One of the hex encoded strings was bad
147 }
148
149 // Add the bytes as characters according to the given encoding
150 result.append(new String(bytes, 0, index, encoding));
151
152 // Make sure we skip to just after a % sign
153 // There might not have been enough encoded characters after the %
154 // or the hex chars were not actually hex chars (NumberFormatException)
155 if (start < length && s.charAt(start) == '%')
156 {
157 result.append('%');
158 start++;
159 }
160 }
161
162 // Add any characters left
163 if (start < str.length())
164 result.append(str.substring(start));
165
166 return result.toString();
167 }
168
169} // class URLDecoder
Note: See TracBrowser for help on using the repository browser.