urlencode AND urldecode

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 异常。解码器具体采用哪种方法取决于实现。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python中的`urlencode`和`urldecode`是用于处理URL编码和解码的方法。 `urlencode`方法用于将一个字典形式的参数列表转换为URL编码的字符串。例如,假设有一个字典`params`包含以下键值对: ``` params = {"name": "张三", "age": 20, "city": "北京"} ``` 使用`urlencode`方法将字典转换为URL编码的字符串: ``` import urllib.parse url_encoded = urllib.parse.urlencode(params) print(url_encoded) ``` 输出结果为: ``` name=%E5%BC%A0%E4%B8%89&age=20&city=%E5%8C%97%E4%BA%AC ``` `urldecode`方法用于将URL编码的字符串解码为字典形式的参数列表。例如,将上面的URL编码字符串解码为字典: ```python import urllib.parse url_decoded = urllib.parse.parse_qs(url_encoded) print(url_decoded) ``` 输出结果为: ``` {'name': ['张三'], 'age': ['20'], 'city': ['北京']} ``` 可以通过访问字典的键来获取对应的值: ```python name = url_decoded['name'][0] age = url_decoded['age'][0] city = url_decoded['city'][0] print(f"姓名:{name},年龄:{age},城市:{city}") ``` 输出结果: ``` 姓名:张三,年龄:20,城市:北京 ``` 通过这两个方法,我们可以方便地进行URL编码和解码的操作,以便于在HTTP请求或其他URL相关的场景中使用。 ### 回答2: Python中的urlencode方法是将字典数据编码为URL参数的字符串。它将字典键值对转换为一组key=value对,并用&符号链接起来。这通常用于构建GET请求的URL参数部分。 例如,将以下字典数据编码为URL参数字符串: ``` params = {'name': '张三', 'age': 20, 'city': '北京'} ``` 通过使用urlencode方法,我们可以得到如下结果: ``` encoded_params = urllib.parse.urlencode(params) print(encoded_params) ``` 输出结果为:name=%E5%BC%A0%E4%B8%89&age=20&city=%E5%8C%97%E4%BA%AC urldecode的功能与urlencode相反,它用于将URL参数字符串解码为字典数据。例如,将上面编码后的字符串解码为字典数据: ``` decoded_params = urllib.parse.parse_qs(encoded_params) print(decoded_params) ``` 输出结果为:{'name': ['张三'], 'age': ['20'], 'city': ['北京']} 注意,这里使用了urllib.parse模块来进行编码和解码。在Python 3中,urllib模块已经被拆分为多个子模块,其中urllib.parse包含了URL编码和解码相关的功能。 综上所述,Python中的urlencodeurldecode方法提供了方便的对URL参数进行编码和解码的功能,可以用于构建和解析GET请求的URL参数部分。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值