javascript对url进行编码和解码

这里总结下JavaScript对URL进行编码和解码的三个方法。

为什么要对URL进行编码和解码

只有【0-9[a-Z] $ - _ . + ! * ‘ ( ) ,】以及某些保留字,才能不经过编码直接用于URL,其他的字符如果不经过编码可能会导致各种各样的问题。

很容易找到编码和解码的例子,比如在搜索引擎搜索的中文关键字,复制网址之后再粘贴会发现该URL已经被转码。

escape()和unescape()

原理:对除ASCII字母、数字、标点符号【@  *  _  +  -  .  /】以外的其他字符进行编码。

编码:escape(‘http://[email protected]=yanggb‘)

结果:"http%3A//www.baidu.com%3Fname%[email protected]%3Dyanggb"

编码:escape(‘杨冠标‘)

结果:"%u6768%u51A0%u6807"

解码:unescape(‘http%3A//www.baidu.com%3Fname%[email protected]%3Dyanggb‘)

结果:"http://[email protected]=yanggb"

编码:unescape(‘%u6768%u51A0%u6807‘)

结果:"杨冠标"

encodeURI()和decodeURI()

encodeURI()是Javascript中真正用来对URL编码的函数。

原理:返回编码为有效的统一资源标识符 (URI) 的字符串,不会被编码的字符:【! @ # $ & * ( ) = : / ; ? + ‘】。

编码:encodeURI(‘http://www.baidu.com?name=杨冠标@blog=yanggb‘)

结果:"http://www.baidu.com?name=%E6%9D%A8%E5%86%A0%E6%A0%[email protected]=yanggb"

解码:decodeURI(‘http://www.baidu.com?name=%E6%9D%A8%E5%86%A0%E6%A0%[email protected]=yanggb‘)

结果:"http://www.baidu.com?name=杨冠标@blog=yanggb"

encodeURIComponent()和decodeURIComponent()

原理:对URL的组成部分进行个别编码,而不用于对整个URL进行编码该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ‘ ( ) 。

编码:encodeURIComponent(‘http://www.baidu.com?name=杨冠标@blog=yanggb‘)

结果:"http%3A%2F%2Fwww.baidu.com%3Fname%3D%E6%9D%A8%E5%86%A0%E6%A0%87%40blog%3Dyanggb"

解码:decodeURIComponent(‘http%3A%2F%2Fwww.baidu.com%3Fname%3D%E6%9D%A8%E5%86%A0%E6%A0%87%40blog%3Dyanggb‘)

结果:"http://www.baidu.com?name=杨冠标@blog=yanggb"

"我从前相信,这世上有一个温暖的人,只为我悲喜,为我阻挡这世间的锋利。"

原文地址:https://www.cnblogs.com/yanggb/p/12021441.html

时间: 2024-11-05 15:58:42

javascript对url进行编码和解码的相关文章

java中URL 的编码和解码函数

java中URL 的编码和解码函数java.net.URLEncoder.encode(String s)和java.net.URLDecoder.decode(String s);在javascript 中URL 的编码和解码函数escape(String s)和unescape(String s) ; 在前台:var url="test.jsp?param="+escape('this%is#te=st&o k?+/');在后台: String param=request.

JavaScript: 详解Base64编码和解码

转载自:http://my.oschina.net/goal/blog/201032#OSC_h2_11 摘要 Base64是最常用的编码之一,比如开发中用于传递参数.现代浏览器中的<img />标签直接通过Base64字符串来渲染图片以及用于邮件中等等.Base64编码在RFC2045中定义,它被定义为:Base64内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式. JavaScript Base64 Unicode UTF16 UTF8 编码 目录[-] 字符编码

js对url进行编码和解码(三种方式区别)

*** 只有 0-9[a-Z] $ - _ . + ! * ' ( ) , 以及某些保留字,才能不经过编码直接用于 URL. ***例如:搜索的中文关键字,复制网址之后再粘贴就会发现该URL已经被转码. 1)escape 和 unescape 原理:对除ASCII字母.数字.标点符号 @ * _ + - . / 以外的其他字符进行编码. 编码: eg:escape('http://[email protected]@jie&order=你好') res:"http%3A//www.bai

URL地址编码和解码

0. 参考 [整理]关于http(GET或POST)请求中的url地址的编码(encode)和解码(decode) python3中的urlopen对于中文url是如何处理的? 中文URL的编码问题 1. rfc1738 2.1. The main parts of URLs A full BNF description of the URL syntax is given in Section 5. In general, URLs are written as follows: <schem

JavaScript对浏览器的URL进行编码、解码

关于url编码,js有三个函数.有三个解码方法,escape,encodeURI,encodeURIComponent().有三个解码方法,unescapse,decodeURI,decodeURIComponent. 1.escape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值.比如"春节"的返回结果是%u6625%u8282,,escape()不对"+"编码主要用于汉字编码,现在已经不提倡使用.对应的解码函数是:unescapse

URL进行编码和解码函数

encodeURIComponent(URIstring) 可把字符串作为URI 组件进行编码. URIstring 必需.一个字符串,含有 URI 组件或其他要编码的文本. urldecode(string str); 本函数将 URL 编码后字符串还原成未编码的样子.编码使用 %## 的格式.

python+requests——URL的编码和解码

from urllib.parse import quote,unquote d = {'lang':'python','type':'testing','ccountry':quote('中国')} print(d) #执行结果:{'lang': 'python', 'type': 'testing', 'ccountry': '%E4%B8%AD%E5%9B%BD'} print(unquote('%E4%B8%AD%E5%9B%BD')) #执行结果:中国 原文地址:https://www

http协议中的编码和解码

http://www.csdn1 2 3.com/html/itweb/20130730/29422_29378_29408.htm ****************************** 一.字符集与文字编码简介 1. 计算机如何显示文字 我们知道,计算机是以二进制的“形式”来保存和处理数据的,也 就是说,不管我们使用键盘进行输入,还是让计算机去读取一个文本文件,计算机得到的原始内容是一些二进制序列,当需要对这些二进制序列进行显示时,计算机 会依照某种“翻译机制”(也就是编码方式),取到

html和Url转码与解码

JS (JQuery)对Html.URL的编码与解码 首先引入JQuery文件 1.js对Html编码 function htmlEncode(value){ return $('<div/>').text(value).html(); } 2.js对Html解码 function htmlDecode(value){ return $('<div/>').html(value).text(); } 3.js对Url编码 function urlEncode(value){ ret