日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

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

來源: 責(zé)編: 時(shí)間:2024-01-02 09:27:53 206觀看
導(dǎo)讀今天介紹兩個(gè)庫 qs、querystring,但是作用一樣,都是用來解析和格式化 URL query 字符串(URL query string)的工具庫。背景在學(xué)習(xí) express 的中間件 body-parser 的文檔[1]時(shí),bodyParser.urlencoded([options]) 的 options

今天介紹兩個(gè)庫 qs、querystring,但是作用一樣,都是用來解析和格式化 URL query 字符串(URL query string)的工具庫。4d828資訊網(wǎng)——每日最新資訊28at.com

背景

在學(xué)習(xí) express 的中間件 body-parser 的文檔[1]時(shí),bodyParser.urlencoded([options]) 的 options 參數(shù)有一個(gè) extended 參數(shù),是個(gè)布爾值。4d828資訊網(wǎng)——每日最新資訊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 內(nèi)部在解析  URL query 字符串時(shí),內(nèi)部使用哪個(gè)工具庫:4d828資訊網(wǎng)——每日最新資訊28at.com

  • 為 false 時(shí),body-parser 內(nèi)部使用的是 querystring(只支持單層對(duì)象和數(shù)組的解析)
  • 為 true 時(shí),body-parser 內(nèi)部使用的是 qs(能支持嵌套對(duì)象和數(shù)組的解析)

extended 默認(rèn)值雖然為 true,但這個(gè)默認(rèn)值已被棄用了。我們需要學(xué)習(xí) qs 和 querystring 之間的區(qū)別并選擇適當(dāng)?shù)倪M(jìn)行設(shè)置。4d828資訊網(wǎng)——每日最新資訊28at.com

我們下面就分別來學(xué)習(xí)。4d828資訊網(wǎng)——每日最新資訊28at.com

querystring

querystring 開始是一個(gè)三方工具庫,后面內(nèi)置到了 Node.js 中[2],querystring 支持單層對(duì)象和數(shù)組的解析和格式化4d828資訊網(wǎng)——每日最新資訊28at.com

你可以通過下列方式引用 querystring:4d828資訊網(wǎng)——每日最新資訊28at.com

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

querystring 提供的核心方法就 2 個(gè):.parse() 和 .stringify() 有點(diǎn)類似與 JSON.parse()/JSON.stringify()。4d828資訊網(wǎng)——每日最新資訊28at.com

querystring.parse()

.parse() 用來將 URL query 字符串轉(zhuǎn)換成對(duì)象和數(shù)組。4d828資訊網(wǎng)——每日最新資訊28at.com

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

URL query 字符串中,鍵值對(duì)采用 = 連接,每個(gè)鍵值對(duì)之間采用 & 連接。4d828資訊網(wǎng)——每日最新資訊28at.com

如果 URL query 字符串包含一樣的鍵名,那么會(huì)作為數(shù)組解析。4d828資訊網(wǎng)——每日最新資訊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]]]) 。4d828資訊網(wǎng)——每日最新資訊28at.com

  • 第 2 個(gè)參數(shù) sep 用于控制鍵值對(duì)之間的間隔,默認(rèn)值 '&'
  • 第 3 個(gè)參數(shù) eq 用于控制鍵值之間的間隔,默認(rèn)值 '='
const querystring = require('node:querystring'); querystring.parse('foo:bar;abc:xyz;abc:123', ';', ':')/*{  "foo": "bar",  "abc": ["xyz", "123"]}*/

querystring.stringify()

.stringify() 用來將對(duì)象或數(shù)組轉(zhuǎn)換成 URL query 字符串,是 .parse() 方法的逆向操作。4d828資訊網(wǎng)——每日最新資訊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]]])。4d828資訊網(wǎng)——每日最新資訊28at.com

  • 第 2 個(gè)參數(shù) sep 用于控制鍵值對(duì)之間的間隔,默認(rèn)值 '&'
  • 第 3 個(gè)參數(shù) eq 用于控制鍵值之間的間隔,默認(rèn)值 '='
querystring.stringify({ foo: 'bar', baz: ['qux', 'quux'], corge: '' }, ';', ':');// Returns 'foo:bar;baz:qux;baz:quux;corge:'

qs

qs[3] 是對(duì) querystring 工具庫的擴(kuò)展,能支持嵌套對(duì)象和數(shù)組的解析和格式化。4d828資訊網(wǎng)——每日最新資訊28at.com

qs.parse()

.parse() 用來將 URL query 字符串轉(zhuǎn)換成對(duì)象和數(shù)組·。4d828資訊網(wǎng)——每日最新資訊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'] }

可以發(fā)現(xiàn),qs.parse() 對(duì)數(shù)組的解析是兼容 querystring.parse() 的,還可以在鍵中使用 [] 指定顯式指定是數(shù)組。4d828資訊網(wǎng)——每日最新資訊28at.com

此外,qs.parse() 還支持嵌套對(duì)象的解析。4d828資訊網(wǎng)——每日最新資訊28at.com

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

鍵部分,[nestedProp] 中的 nestdProp 會(huì)被看作嵌套屬性解析。4d828資訊網(wǎng)——每日最新資訊28at.com

不過為了減少這個(gè)功能的濫用,qs.parse() 默認(rèn)設(shè)置了 5 層的深度限制,可以通過 depth option 重置。4d828資訊網(wǎng)——每日最新資訊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 嵌套屬性語法跟數(shù)組語法是重復(fù)的。數(shù)組中的索引和對(duì)象中的鍵之間的唯一區(qū)別是括號(hào)之間的值必須是數(shù)字才能創(chuàng)建數(shù)組,否則就是對(duì)象。4d828資訊網(wǎng)——每日最新資訊28at.com

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

不過為了減少這個(gè)功能的濫用,qs.parse() 默認(rèn)將數(shù)組中指定的索引值限制到最大 20 ,任何索引大于 20 的索引都會(huì)作為對(duì)象屬性使用。可以通過 arrayLimit option 重置。4d828資訊網(wǎng)——每日最新資訊28at.com

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

qs.stringify()

qs.stringify() 用來將對(duì)象或數(shù)組轉(zhuǎn)換成 URL query 字符串,是 qs.parse() 方法的逆向操作。4d828資訊網(wǎng)——每日最新資訊28at.com

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

字符串化時(shí),qs 默認(rèn)對(duì) URI 進(jìn)行編碼輸出。當(dāng)然,也可以通過指定 encode option 設(shè)置成 false 指定不用編碼。4d828資訊網(wǎng)——每日最新資訊28at.com

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

還有字符串化數(shù)組。4d828資訊網(wǎng)——每日最新資訊28at.com

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

注意,這里跟 querystring.stringify() 不同的是,數(shù)組默認(rèn)會(huì)賦予索引標(biāo)識(shí)([]),可以通過將 indices option 設(shè)置為 false 來覆蓋此設(shè)置。4d828資訊網(wǎng)——每日最新資訊28at.com

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

4d828資訊網(wǎng)——每日最新資訊28at.com

delimiter 選項(xiàng)參數(shù)

qs.stringify()/qs.parse() 還支持通過 delimiter 選項(xiàng)參數(shù)自定義鍵值對(duì)分隔符。4d828資訊網(wǎng)——每日最新資訊28at.com

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

不過,目前并不支持自定義鍵值之間的分隔符。4d828資訊網(wǎng)——每日最新資訊28at.com

總結(jié)

本文介紹了兩個(gè)庫:qs 和 querystring。他們作用是一樣的,都是用來解析和格式化 URL query 字符串的工具庫。4d828資訊網(wǎng)——每日最新資訊28at.com

qs 是對(duì) querystring 工具庫的擴(kuò)展。querystring 支持單層對(duì)象和數(shù)組的解析和格式化;而 qs 則能支持嵌套對(duì)象和數(shù)組的解析和格式化。如果 URL query 字符串不是那種嵌套結(jié)構(gòu),那么使用 Node.js 內(nèi)置的 querystring 模塊就夠了。4d828資訊網(wǎng)——每日最新資訊28at.com

對(duì)應(yīng)到 express 的 body-parser 中間件的使用,那就是在調(diào)用 bodyParser.urlencoded() 時(shí),extended 選項(xiàng)設(shè)置成 false 就夠了。4d828資訊網(wǎng)——每日最新資訊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)})

希望本文內(nèi)容對(duì)你有所幫助,感謝閱讀,Happing Coding!4d828資訊網(wǎng)——每日最新資訊28at.com

參考資料

[1]body-parser 的文檔:https://www.npmjs.com/package/body-parser#body-parser4d828資訊網(wǎng)——每日最新資訊28at.com

[2]內(nèi)置到了 Node.js 中:https://nodejs.org/api/querystring.html4d828資訊網(wǎng)——每日最新資訊28at.com

[3]qs:https://www.npmjs.com/package/qs4d828資訊網(wǎng)——每日最新資訊28at.com

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

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: 用RASP五步輕松保護(hù)云端無服務(wù)器架構(gòu)

下一篇: 多人多團(tuán)隊(duì)?wèi)?yīng)該如何實(shí)施微服務(wù)?版本如何管理?

標(biāo)簽:
  • 熱門焦點(diǎn)
  • 盧偉冰長文解析K60至尊版 對(duì)Redmi有著里程碑式的意義

    在今天的Redmi后性能時(shí)代戰(zhàn)略發(fā)布會(huì)結(jié)束之后,Redmi總經(jīng)理盧偉冰又帶來了一篇長文,詳解了為什么 Redmi 要開啟后性能時(shí)代?為什么選擇和 MediaTek、Pixelworks 深度合作?以及后性
  • 0糖0卡0脂 旭日森林仙草烏龍茶優(yōu)惠:15瓶到手29元

    旭日森林無糖仙草烏龍茶510ml*15瓶平時(shí)要賣為79.9元,今日下單領(lǐng)取50元優(yōu)惠券,到手價(jià)為29.9元。產(chǎn)品規(guī)格:0糖0卡0脂,添加草本仙草汁,清涼爽口,富含茶多酚,保留
  • Rust中的高吞吐量流處理

    作者 | Noz編譯 | 王瑞平本篇文章主要介紹了Rust中流處理的概念、方法和優(yōu)化。作者不僅介紹了流處理的基本概念以及Rust中常用的流處理庫,還使用這些庫實(shí)現(xiàn)了一個(gè)流處理程序
  • 把LangChain跑起來的三個(gè)方法

    使用LangChain開發(fā)LLM應(yīng)用時(shí),需要機(jī)器進(jìn)行GLM部署,好多同學(xué)第一步就被勸退了,那么如何繞過這個(gè)步驟先學(xué)習(xí)LLM模型的應(yīng)用,對(duì)Langchain進(jìn)行快速上手?本片講解3個(gè)把LangChain跑起來
  • 共享單車的故事講到哪了?

    來源丨海克財(cái)經(jīng)與共享充電寶相差不多,共享單車已很久沒有被國內(nèi)熱點(diǎn)新聞關(guān)照到了。除了一再漲價(jià)和用戶直呼用不起了。近日多家媒體再發(fā)報(bào)道稱,成都、天津、鄭州等地多個(gè)共享單
  • 中國家電海外掘金正當(dāng)時(shí)|出海專題

    作者|吳南南編輯|胡展嘉運(yùn)營|陳佳慧出品|零態(tài)LT(ID:LingTai_LT)2023年,出海市場戰(zhàn)況空前,中國創(chuàng)業(yè)者在海外紛紛摩拳擦掌,以期能夠把中國的商業(yè)模式、創(chuàng)業(yè)理念、戰(zhàn)略打法輸出海外,他們依
  • AI芯片初創(chuàng)公司Tenstorrent獲三星和現(xiàn)代1億美元投資

    Tenstorrent是一家由芯片行業(yè)資深人士Jim Keller領(lǐng)導(dǎo)的加拿大初創(chuàng)公司,專注于開發(fā)人工智能芯片,該公司周三表示,已經(jīng)從現(xiàn)代汽車集團(tuán)和三星投資基金等
  • 支持aptX Lossless無損傳輸 iQOO TWS 1賽道版發(fā)布限時(shí)優(yōu)惠價(jià)369元

    2023年7月4日,“無損音質(zhì),聲動(dòng)人心”iQOO TWS 1正式發(fā)布,支持aptX Lossless無損傳輸,限時(shí)優(yōu)惠價(jià)369元。iQOO TWS 1耳機(jī)率先支持端到端aptX Lossless無
  • iQOO Neo8 Pro即將開售:到手價(jià)3099元起 安卓性能最強(qiáng)旗艦

    5月23日,iQOO如期舉行了新品發(fā)布會(huì),全新的iQOO Neo8系列也正式與大家見面,包含iQOO Neo8和iQOO Neo8 Pro兩個(gè)版本,其中標(biāo)準(zhǔn)版搭載高通驍龍8+,而Pro版更
Top 主站蜘蛛池模板: 礼泉县| 竹溪县| 湖南省| 阿拉善左旗| 诸城市| 突泉县| 搜索| 紫云| 宾阳县| 奉化市| 东兴市| 无锡市| 永昌县| 洪洞县| 乐山市| 长海县| 连江县| 历史| 休宁县| 鄂州市| 白河县| 三江| 博乐市| 溧阳市| 湘阴县| 治县。| 万州区| 革吉县| 加查县| 白朗县| 五华县| 潜山县| 且末县| 美姑县| 淅川县| 林甸县| 榆林市| 抚顺市| 保康县| 滦平县| 漯河市|