当前位置:首页 > 科技  > 软件

Qs 和 Querystring:解析和格式化 URL query 字符串的工具库

来源: 责编: 时间:2024-01-02 09:27:53 293观看
导读今天介绍两个库 qs、querystring,但是作用一样,都是用来解析和格式化 URL query 字符串(URL query string)的工具库。背景在学习 express 的中间件 body-parser 的文档[1]时,bodyParser.urlencoded([options]) 的 options

今天介绍两个库 qs、querystring,但是作用一样,都是用来解析和格式化 URL query 字符串(URL query string)的工具库。Xwv28资讯网——每日最新资讯28at.com

背景

在学习 express 的中间件 body-parser 的文档[1]时,bodyParser.urlencoded([options]) 的 options 参数有一个 extended 参数,是个布尔值。Xwv28资讯网——每日最新资讯28at.com

// parse application/x-www-form-urlencodedapp.use(bodyParser.urlencoded({ extended: false }))// parse application/x-www-form-urlencodedapp.use(bodyParser.urlencoded({ extended: true }))

extended 控制 body-parser 内部在解析  URL query 字符串时,内部使用哪个工具库:Xwv28资讯网——每日最新资讯28at.com

  • 为 false 时,body-parser 内部使用的是 querystring(只支持单层对象和数组的解析)
  • 为 true 时,body-parser 内部使用的是 qs(能支持嵌套对象和数组的解析)

extended 默认值虽然为 true,但这个默认值已被弃用了。我们需要学习 qs 和 querystring 之间的区别并选择适当的进行设置。Xwv28资讯网——每日最新资讯28at.com

我们下面就分别来学习。Xwv28资讯网——每日最新资讯28at.com

querystring

querystring 开始是一个三方工具库,后面内置到了 Node.js 中[2],querystring 支持单层对象和数组的解析和格式化Xwv28资讯网——每日最新资讯28at.com

你可以通过下列方式引用 querystring:Xwv28资讯网——每日最新资讯28at.com

const querystring = require('node:querystring');

querystring 提供的核心方法就 2 个:.parse() 和 .stringify() 有点类似与 JSON.parse()/JSON.stringify()。Xwv28资讯网——每日最新资讯28at.com

querystring.parse()

.parse() 用来将 URL query 字符串转换成对象和数组。Xwv28资讯网——每日最新资讯28at.com

const querystring = require('node:querystring'); querystring.parse('foo=bar&abc=xyz') // { foo: 'bar', abc: 'xyz'  }

URL query 字符串中,键值对采用 = 连接,每个键值对之间采用 & 连接。Xwv28资讯网——每日最新资讯28at.com

如果 URL query 字符串包含一样的键名,那么会作为数组解析。Xwv28资讯网——每日最新资讯28at.com

const querystring = require('node:querystring'); querystring.parse('foo=bar&abc=xyz&abc=123')/*{  "foo": "bar",  "abc": ["xyz", "123"]}*/

.parse() 方法的完整语法是:querystring.parse(str[, sep[, eq[, options]]]) 。Xwv28资讯网——每日最新资讯28at.com

  • 第 2 个参数 sep 用于控制键值对之间的间隔,默认值 '&'
  • 第 3 个参数 eq 用于控制键值之间的间隔,默认值 '='
const querystring = require('node:querystring'); querystring.parse('foo:bar;abc:xyz;abc:123', ';', ':')/*{  "foo": "bar",  "abc": ["xyz", "123"]}*/

querystring.stringify()

.stringify() 用来将对象或数组转换成 URL query 字符串,是 .parse() 方法的逆向操作。Xwv28资讯网——每日最新资讯28at.com

querystring.stringify({ foo: 'bar', baz: ['qux', 'quux'], corge: '' });// Returns 'foo=bar&baz=qux&baz=quux&corge='

.stringify() 方法的完整语法是:querystring.stringify(obj[, sep[, eq[, options]]])。Xwv28资讯网——每日最新资讯28at.com

  • 第 2 个参数 sep 用于控制键值对之间的间隔,默认值 '&'
  • 第 3 个参数 eq 用于控制键值之间的间隔,默认值 '='
querystring.stringify({ foo: 'bar', baz: ['qux', 'quux'], corge: '' }, ';', ':');// Returns 'foo:bar;baz:qux;baz:quux;corge:'

qs

qs[3] 是对 querystring 工具库的扩展,能支持嵌套对象和数组的解析和格式化。Xwv28资讯网——每日最新资讯28at.com

qs.parse()

.parse() 用来将 URL query 字符串转换成对象和数组·。Xwv28资讯网——每日最新资讯28at.com

var qs = require('qs');qs.parse('foo=bar&abc=xyz') // { foo: 'bar', abc: 'xyz'  }qs.parse('a=b&a=c') // { a: ['b', 'c'] }qs.parse('a[]=b&a[]=c') // { a: ['b', 'c'] }

可以发现,qs.parse() 对数组的解析是兼容 querystring.parse() 的,还可以在键中使用 [] 指定显式指定是数组。Xwv28资讯网——每日最新资讯28at.com

此外,qs.parse() 还支持嵌套对象的解析。Xwv28资讯网——每日最新资讯28at.com

qs.parse('foo[bar]=baz')/*{    foo: {        bar: 'baz'    }}*/qs.parse('foo[bar][baz]=foobarbaz')/*{    foo: {        bar: {            baz: 'foobarbaz'        }    }}*/

键部分,[nestedProp] 中的 nestdProp 会被看作嵌套属性解析。Xwv28资讯网——每日最新资讯28at.com

不过为了减少这个功能的滥用,qs.parse() 默认设置了 5 层的深度限制,可以通过 depth option 重置。Xwv28资讯网——每日最新资讯28at.com

qs.parse('a[b][c][d][e][f][g][h][i]=j')/*{    a: {        b: {            c: {                d: {                    e: {                        f: {                            '[g][h][i]': 'j'                        }                    }                }            }        }    }}*/qs.parse('a[b][c][d][e][f][g][h][i]=j', { depth: 1 })/*{ a: { b: { '[c][d][e][f][g][h][i]': 'j' } } }*/

qs 嵌套属性语法跟数组语法是重复的。数组中的索引和对象中的键之间的唯一区别是括号之间的值必须是数字才能创建数组,否则就是对象。Xwv28资讯网——每日最新资讯28at.com

qs.parse('a[1]=c&a[0]=b') // { a: ['b', 'c'] }qs.parse('foo[bar]=baz') // { foo: { bar: 'baz' } }

不过为了减少这个功能的滥用,qs.parse() 默认将数组中指定的索引值限制到最大 20 ,任何索引大于 20 的索引都会作为对象属性使用。可以通过 arrayLimit option 重置。Xwv28资讯网——每日最新资讯28at.com

qs.parse('a[100]=b') // { a: { '100': 'b' } }qs.parse('a[1]=b', { arrayLimit: 0 }) // { a: { '1': 'b' } }

qs.stringify()

qs.stringify() 用来将对象或数组转换成 URL query 字符串,是 qs.parse() 方法的逆向操作。Xwv28资讯网——每日最新资讯28at.com

qs.stringify({ a: 'b' }) // 'a=b'qs.stringify({ a: { b: 'c' } }) // 'a%5Bb%5D=c'

字符串化时,qs 默认对 URI 进行编码输出。当然,也可以通过指定 encode option 设置成 false 指定不用编码。Xwv28资讯网——每日最新资讯28at.com

qs.stringify({ a: { b: 'c' } }, { encode: false }) // a[b]=c

还有字符串化数组。Xwv28资讯网——每日最新资讯28at.com

qs.stringify({ a: ['b', 'c', 'd'] }) // 'a[0]=b&a[1]=c&a[2]=d'

注意,这里跟 querystring.stringify() 不同的是,数组默认会赋予索引标识([]),可以通过将 indices option 设置为 false 来覆盖此设置。Xwv28资讯网——每日最新资讯28at.com

qs.stringify({ a: ['b', 'c', 'd'] }, { indices: false })// 'a=b&a=c&a=d'

Xwv28资讯网——每日最新资讯28at.com

delimiter 选项参数

qs.stringify()/qs.parse() 还支持通过 delimiter 选项参数自定义键值对分隔符。Xwv28资讯网——每日最新资讯28at.com

qs.parse('a=b;c=d', { delimiter: ';' }) // { a: 'b', c: 'd' }

不过,目前并不支持自定义键值之间的分隔符。Xwv28资讯网——每日最新资讯28at.com

总结

本文介绍了两个库:qs 和 querystring。他们作用是一样的,都是用来解析和格式化 URL query 字符串的工具库。Xwv28资讯网——每日最新资讯28at.com

qs 是对 querystring 工具库的扩展。querystring 支持单层对象和数组的解析和格式化;而 qs 则能支持嵌套对象和数组的解析和格式化。如果 URL query 字符串不是那种嵌套结构,那么使用 Node.js 内置的 querystring 模块就够了。Xwv28资讯网——每日最新资讯28at.com

对应到 express 的 body-parser 中间件的使用,那就是在调用 bodyParser.urlencoded() 时,extended 选项设置成 false 就够了。Xwv28资讯网——每日最新资讯28at.com

// express v4.16.0 之前// ===var express = require('express')var bodyParser = require('body-parser')var app = express()// create application/x-www-form-urlencoded parservar urlencodedParser = bodyParser.urlencoded({ extended: false })// POST /login gets urlencoded bodiesapp.post('/login', urlencodedParser, function (req, res) {  res.send('welcome, ' + req.body.username)})// express v4.16.0 之后(包含)// ===var express = require('express')var app = express()// create application/x-www-form-urlencoded parservar urlencodedParser = express.urlencoded({ extended: false })// POST /login gets urlencoded bodiesapp.post('/login', urlencodedParser, function (req, res) {  res.send('welcome, ' + req.body.username)})

希望本文内容对你有所帮助,感谢阅读,Happing Coding!Xwv28资讯网——每日最新资讯28at.com

参考资料

[1]body-parser 的文档:https://www.npmjs.com/package/body-parser#body-parserXwv28资讯网——每日最新资讯28at.com

[2]内置到了 Node.js 中:https://nodejs.org/api/querystring.htmlXwv28资讯网——每日最新资讯28at.com

[3]qs:https://www.npmjs.com/package/qsXwv28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-54968-0.htmlQs 和 Querystring:解析和格式化 URL query 字符串的工具库

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 用RASP五步轻松保护云端无服务器架构

下一篇: 多人多团队应该如何实施微服务?版本如何管理?

标签:
  • 热门焦点
  • K60 Pro官方停产 第三方瞬间涨价

    虽然没有官方宣布,但Redmi的一些高管也已经透露了,Redmi K60 Pro已经停产且不会补货,这一切都是为了即将到来的K60 Ultra铺路,属于厂家的正常操作。但有意思的是该机在停产之后
  • Mate60手机壳曝光 致敬自己的经典设计

    8月3日消息,今天下午博主数码闲聊站带来了华为Mate60的第三方手机壳图,可以让我们在真机发布之前看看这款华为全新旗舰的大致轮廓。从曝光的图片看,Mate 60背后摄像头面积依然
  • Redmi Pad评测:红米充满野心的一次尝试

    从Note系列到K系列,从蓝牙耳机到笔记本电脑,红米不知不觉之间也已经形成了自己颇有竞争力的产品体系,在中端和次旗舰市场上甚至要比小米新机的表现来得更好,正所谓“大丈夫生居
  • 帅气纯真少年!日本最帅初中生选美冠军出炉

    日本第一帅哥初一生选美大赛冠军现已正式出炉,冠军是来自千叶县的宗田悠良。日本一直热衷于各种选美大赛,从“最美JK”起到“最美女星&r
  • 8月总票房已突破10亿!《封神》第一:口碑已经成了

    8月5日消息,据灯塔专业版数据,截至8月5日9时35分,8月总票房(含预售)已突破10亿。其中,《封神》以大比分的优势领先。根据官方消息,目前该片总票房已经超过14.
  • 破圈是B站头上的紧箍咒

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之每年的暑期档都少不了瞄准追剧女孩们的古偶剧集,2021年有优酷的《山河令》,2022年有爱奇艺的《苍兰诀》,今年却轮到小破站抓住了追
  • 三星折叠屏手机去年销售近1000万台 今年目标定为1500万

    7月29日消息,三星率先发力可折叠手机市场,在全球市场已经取得了非常亮眼的成绩,接下来会进一步巩固和扩大这一优势。三星在推出Galaxy Z Flip5和Galax
  • 2299元起!iQOO Pad开启预售:性能最强天玑平板

    5月23日,iQOO如期举行了新品发布会,除了首发安卓最强旗舰处理器的iQOO Neo8系列新机外,还在发布会上推出了旗下首款平板电脑——iQOO Pad,其搭载了天玑
  • 首发天玑9200+ iQOO Neo8系列发布首销售价2299元起

    2023年5月23日晚,iQOO Neo8系列正式发布。其中,Neo系列首款Pro之作——iQOO Neo8 Pro强悍登场,限时售价3099元起;价位段最强性能手机iQOO Neo8同期上市
Top