美文网首页
url如何编码解码?为什么要编码?

url如何编码解码?为什么要编码?

作者: Zulu_c02a | 来源:发表于2020-09-07 17:01 被阅读0次

    1.为什们要编码

    一般来说,URL只能使用英文字母、阿拉伯数字和某些标点符号,不能使用其他文字和符号,这是因为网络标准RFC 1738做了硬性规定。如果URL中有汉字,就必须编码后使用。但是麻烦的是,RFC 1738没有规定具体的编码方法,而是交给应用程序(浏览器)自己决定,这导致"URL编码"成为了一个混乱的领域。
    四种导致混乱的情况:
    网址路径中包含汉字
    查询字符串包含汉字
    Get方法生成的URL包含汉字
    Ajax调用的URL包含汉字(在Ajax调用中,IE总是采用GB2312编码(操作系统的默认编码),而Firefox总是采用utf-8编码。)
    综上所述,这个时候需要一种编码方法向服务器发送请求,而js则可以满足这一需求。

    2.js的URL的编码/解码方法

    decodeURI()
    decodeURIComponent()
    encodeURI()
    encodeURIComponent() (一般使用encodeURI()和encodeURIComponent())

    encodeURI()

    encodeURI()是Javascript中真正用来对URL编码的函数。它着眼于对整个URL进行编码,因此除了常见的符号以外,对其他一些在网址中有特殊含义的符号"; / ? : @ & = + $ , #",也不进行编码。编码后,它输出符号的utf-8形式,并且在每个字节前加上%。

    encodeURI方法不会对下列字符编码

    1. ASCII字母
    2. 数字
    3. ~!@#$&*()=:/,;?+'
    image.png

    它对应的解码函数是decodeURI()


    image.png

    注意:需要注意的是,它不对单引号'编码。

    encodeURIComponent()

    与encodeURI()的区别是,它用于对URL的组成部分进行个别编码,而不用于对整个URL进行编码。因此,"; / ? : @ & = + $ , #",这些在encodeURI()中不被编码的符号,在encodeURIComponent()中统统会被编码。至于具体的编码方法,两者是一样。

    encodeURIComponent方法不会对下列字符编码

    1. ASCII字母
    2. 数字
    3. ~!*()'
    image.png

    它对应的解码函数是decodeURIComponent()。

    总结

    encodeURIComponent比encodeURI编码的范围更大。
    举例来说,encodeURIComponent会把 http:// 编码成 http%3A%2F%2F 而encodeURI却不会。
    如果你需要编码整个URL,然后需要使用这个URL,那么用encodeURI,否则使用encodeURIComponent。

    参考http://www.ruanyifeng.com/blog/2010/02/url_encoding.html

    相关文章

      网友评论

          本文标题:url如何编码解码?为什么要编码?

          本文链接:https://www.haomeiwen.com/subject/tsrlektx.html