URLEncode的作用到底是什么呢?什么情况下非要用URLEncode方法呢?
不用URLEncode和用了URLEncode后会有什么不同,能否给个例子看看!谢谢!
例如:
一产品名称为A&T Plastic,在产品列表中就产生了这样的一个联接<a href="product.asp?name=A&T Plastic">A&T Plastic</a>,在服务器端接收此参数的时候怎么也无法接收到准确的产品名。
-->用urlencode方法
特殊特殊字符的含义
————————————————————————————
字符 特殊字符的含义 URL编码
# 用来标志特定的文档位置 %23
% 对特殊字符进行编码 %25
& 分隔不同的变量值对 %26
+ 在变量值中表示空格 %2B
/ 表示目录路径 %2F
= 用来连接键和值 %3D
? 表示查询字符串的开始 %3F
当键值中含有以上列表中的一些字符时就无法准确的接收其中的值。
'定义含有特殊字符的字符串
str="parameter=#%&+/=?value</html>"
'用URLEncode方法进行编码
strurlencode=server.URLEncode(str)
'用HTMLEncode方法进行编码
strhtmlencode=server.HTMLEncode (str)
'显示所有的querysting字符
Response.Write "<b>QueryString:<b>"
Response.Write Request.QueryString
'显示传递的参数
Response.Write "<b>Parameter is:</b>" & str
Response.Write "<b>QueryParameter=</b>"
Response.Write Request.QueryString ("str")
<P><a href="01.asp?str=<%=strurlencode%>">Str UrlEncode Method</a></P>
<P> </P>
<P><a href="01.asp?str=<%=strhtmlencode%>">Str HtmlEncode Method</a></P>
下面还可以补充的:
对与全文检索引擎而言.如果要在URL上面建立全文索引,最好是DECODE以的URL
java urlencode编解码
自己工程里常用到,大家共享一下~共同提高,高手多多指点啊
//类似于asp中htmlencode函数的jsp函数
public static String HTMLEncode(String text) {
if (text == null)
return "";
StringBuffer results = null;
char[] orig = null;
int beg = 0, len = text.length();
for (int i = 0; i < len; ++i) {
char c = text.charAt(i);
switch (c) {
case 0:
case '&':
case '<':
case '>':
case '"':
if (results == null) {
orig = text.toCharArray();
results = new StringBuffer(len + 10);
}
if (i > beg)
results.append(orig, beg, i - beg);
beg = i + 1;
switch (c) {
default: // case 0:
continue;
case '&':
results.append("&");
break;
case '<':
results.append("<");
break;
case '>':
results.append(">");
break;
case '"':
results.append("/"");
break;
}
break;
}
}
if (results == null)
return text;
results.append(orig, beg, len - beg);
return results.toString();
}
//类似于asp中urlencode函数的jsp函数
public static String URLEncode(String text) {
StringBuffer StrUrl = new StringBuffer();
for (int i = 0; i < text.length(); ++i) {
switch (text.charAt(i)) {
case ' ':
StrUrl.append("%20");
break;
case '+':
StrUrl.append("%2b");
break;
case '/'':
StrUrl.append("%27");
break;
case '/':
StrUrl.append("%2F");
break;
case '.':
StrUrl.append("%2E");
break;
case '<':
StrUrl.append("%3c");
break;
case '>':
StrUrl.append("%3e");
break;
case '#':
StrUrl.append("%23");
break;
case '%':
StrUrl.append("%25");
break;
case '&':
StrUrl.append("%26");
break;
case '{':
StrUrl.append("%7b");
break;
case '}':
StrUrl.append("%7d");
break;
case '//':
StrUrl.append("%5c");
break;
case '^':
StrUrl.append("%5e");
break;
case '~':
StrUrl.append("%73");
break;
case '[':
StrUrl.append("%5b");
break;
case ']':
StrUrl.append("%5d");
break;
default:
StrUrl.append(text.charAt(i));
break;
}
}
return StrUrl.toString();
}
用现成的函数即可:
java.net.URLEncoder.encode()
java.net.URLDecoder.decode()
< type="text/javascript"> < type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> < type="text/javascript"> < type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
=================
public class URLEncoderextends ObjectHTML 格式编码的实用工具类。该类包含了将 String 转换为 application/x-www-form-urlencoded MIME 格式的静态方法。有关 HTML 格式编码的更多信息,请参阅 HTML 规范。
对 String 编码时,使用以下规则:
字母数字字符 "a" 到 "z"、"A" 到 "Z" 和 "0" 到 "9" 保持不变。
特殊字符 "."、"-"、"*" 和 "_" 保持不变。
空格字符 " " 转换为一个加号 "+"。
所 有其他字符都是不安全的,因此首先使用一些编码机制将它们转换为一个或多个字节。然后每个字节用一个包含 3 个字符的字符串 "%xy" 表示,其中 xy 为该字节的两位十六进制表示形式。推荐的编码机制是 UTF-8。但是,出于兼容性考虑,如果未指定一种编码,则使用相应平台的默认编码。
例 如,使用 UTF-8 编码机制,字符串 "The string ü@foo-bar" 将转换为 "The+string+%C3%BC%40foo-bar",因为在 UTF-8 中,字符 ü 编码为两个字节,C3 (十六进制)和 BC (十六进制),字符 @ 编码为一个字节 40 (十六进制)。
public class URLDecoderextends ObjectHTML 格式解码的实用工具类。该类包含了将 String 从 application/x-www-form-urlencoded MIME 格式解码的静态方法。
该 转换过程正好与 URLEncoder 类使用的过程相反。假定已编码的字符串中的所有字符为下列之一:"a" 到 "z"、"A" 到 "Z"、"0" 到 "9" 和 "-"、"_"、"." 以及 "*"。允许有 "%" 字符,但是将它解释为特殊转义序列的开始。
转换中使用以下规则:
字母数字字符 "a" 到 "z"、"A" 到 "Z" 和 "0" 到 "9" 保持不变。
特殊字符 "."、"-"、"*" 和 "_" 保持不变。
加号 "+" 转换为空格字符 " "。
将 把 "%xy" 格式序列视为一个字节,其中 xy 为 8 位的两位十六进制表示形式。然后,所有连续包含一个或多个这些字节序列的子字符串,将被其编码可生成这些连续字节的字符所代替。可以指定对这些字符进行解 码的编码机制,或者如果未指定的话,则使用平台的默认编码机制。
该解码器处理非法字符串有两种可能的方法。一种方法是不管该非法字符,另一种方法是抛出 IllegalArgumentException 异常。解码器具体采用哪种方法取决于实现。