URL编码【详解】——Javascript对URL进行编码解码的三种方式的区别和使用场景,axios请求拦截器中对get请求的参数全部进行URL编码

简介: URL编码【详解】——Javascript对URL进行编码解码的三种方式的区别和使用场景,axios请求拦截器中对get请求的参数全部进行URL编码

为什么需要URL编码?

根据网络标准RFC 1738的硬性规定:

"只有字母和数字[0-9a-zA-Z]、一些特殊符号"$-_.+!*'(),"[不包括双引号]、以及某些保留字,才可以不经过编码直接用于URL。"

即URL不支持汉字,[] 等字符。

但在使用URL传参时(如get请求),参数值经常包含汉字,[] 等字符,怎么办?

将这些URL不支持的字符进行编码后使用。

如  https://www.baidu.com/s?wd=春节  编码后为  春节_百度搜索

为什么浏览器中的网址可以有中文等URL不支持的字符?

因为浏览器对非法URL自动进行了编码!

虽然浏览器的地址栏中,看到的URL包含中文,但实际的网络请求对URL进行了编码

为什么要主动对URL进行编码?

虽然浏览器自己会对URL进行编码,但不同的操作系统、不同的浏览器、不同的网页字符集,将导致完全不同的编码结果。(详见 关于URL编码 - 阮一峰的网络日志 )

服务器不可能对错综复杂的编码结果进行处理,所以,需要使用Javascript先对URL编码,然后再向服务器提交,不给浏览器插手的机会。

因为Javascript的输出总是一致的,就保证了服务器得到的数据格式的统一。

Javascript对URL进行编码

以下三种函数都可以对URL进行编码,区别主要在于不编码的字符不同,具体使用详见各自的使用场景:

encodeURIComponent() 【推荐】

  • 使用场景:对url中的参数进行编码
  • 不编码的字符: ~!*()

encodeURI()

  • 使用场景:对整个url进行编码
  • 不编码的字符: ~!@#@{content}*()=:/,;?+'

escape() 【不推荐】

  • 不编码的字符:@*/+
  • 在用户提交的表单字段中,如果有空格,则会被转化为+字符,而服务器解析的时候则会认为+号代表空格。由于这个缺陷,应当尽量避免使用escape方法。

Javascript对URL进行解码

当Javascript需要从URL中解析出参数时,获取到的URL通常是已编码的,所以需要先对URL进行解码,再进行解析。

以下三种函数都可以对URL进行解码,与编码函数一一对应。

  • unencodeURIComponent(string)
  • unencodeURI(string)
  • unescape(string)

实战案例——axios请求拦截器中,对get请求的参数全部进行URL编码

// 添加请求拦截器
axios.interceptors.request.use(function(config) {
 
    // 对get请求的参数全部进行URL编码
    let url = config.url
 
    if (config.method === 'get' && config.params) {
        url += '?'
        let keys = Object.keys(config.params)
        for (let key of keys) {
            url += `${key}=${encodeURIComponent(config.params[key])}&`
        }
        url = url.substring(0, url.length - 1)
        config.params = {}
    }
    config.url = url
 
    return config;
}, function(error) {
    return Promise.reject(error);
});

目录
相关文章
|
1月前
|
JavaScript 前端开发 索引
js遍历的方法与区别
js遍历的方法与区别
43 3
|
1月前
|
网络协议 安全
|
1月前
|
JavaScript 前端开发 索引
js的循环中foreach、for in和for of的区别
js的循环中foreach、for in和for of的区别
100 0
|
1月前
|
Python
axios的get请求传入数组参数
axios的get请求传入数组参数
|
18天前
|
JavaScript 前端开发
JavaScript基础知识-函数的参数
关于JavaScript函数参数基础知识的介绍。
17 4
JavaScript基础知识-函数的参数
|
15天前
|
前端开发 JavaScript API
JavaScript 的宏任务和微任务有什么区别
【9月更文挑战第6天】JavaScript 的宏任务和微任务有什么区别
15 4
|
7天前
|
前端开发 JavaScript UED
JavaScript防抖和节流的使用及区别
JavaScript防抖和节流的使用及区别
7 0
|
20天前
|
存储 JavaScript 前端开发
|
1月前
|
JavaScript 前端开发 Java
Java和JavaScript区别与联系
【8月更文挑战第18天】
|
1月前
|
移动开发 JavaScript 前端开发
"解锁axios GET请求新姿势!揭秘如何将数组参数华丽变身,让你的HTTP请求在云端翩翩起舞,挑战技术极限!"
【8月更文挑战第20天】二维码在移动应用中无处不在。本文详述了在UniApp H5项目中实现二维码生成与扫描的方法。通过对比插件`uni-app-qrcode`和库`qrcode-generator`生成二维码,以及使用插件和HTML5 API进行扫描,帮助开发者挑选最佳方案。无论是即插即用的插件还是灵活的JavaScript实现,都能满足不同需求。
26 0