Node.JS獲取GET,POST數(shù)據(jù)之queryString模塊使用方法詳解
無(wú)論是前端還是后端,經(jīng)常出現(xiàn)的應(yīng)用場(chǎng)景是URL中參數(shù)的處理。nodeJS的queryString模塊提供了一些處理 query strings 的工具。本文將詳細(xì)介紹nodeJS中的queryString
var querystring = require('querystring'); /* { unescapeBuffer: [Function], unescape: [Function: qsUnescape], escape: [Function], encode: [Function], stringify: [Function], decode: [Function], parse: [Function] } */ console.log(querystring);
序列化
querystring.parse(str[, sep[, eq[, options]]])
querystring.parse()方法能把一個(gè)URL查詢(xún)字符串(str)解析成一個(gè)鍵值對(duì)的集合,參數(shù)如下
str <String> 要解析的 URL 查詢(xún)字符串。
sep <String> 用于界定查詢(xún)字符串中的鍵值對(duì)的子字符串。默認(rèn)為 '&'。
eq <String> 用于界定查詢(xún)字符串中的鍵與值的子字符串。默認(rèn)為 '='。
options <Object>
decodeURIComponent <Function> 當(dāng)解碼查詢(xún)字符串中百分號(hào)編碼的字符時(shí)使用的函數(shù)。默認(rèn)為 querystring.unescape()
maxKeys <number> 指定要解析的鍵的最大數(shù)量。默認(rèn)為 1000。指定為 0 則移除鍵數(shù)的限制
var querystring = require('querystring'); var str = 'foo=bar&abc=xyz&abc=123'; console.log(querystring.parse(str));//'{ foo: 'bar', abc: [ 'xyz', '123' ] }'
第二個(gè)參數(shù)用于界定查詢(xún)字符串中的鍵值對(duì)的子字符串
var querystring = require('querystring'); var str = 'foo=bar&abc=xyz&abc=123'; console.log(querystring.parse(str,'a'));//{ foo: 'b', 'r&': '', bc: [ 'xyz&', '123' ] }
第三個(gè)參數(shù)用于界定查詢(xún)字符串中的鍵與值的子字符串
var querystring = require('querystring'); var str = 'foo=bar&abc=xyz&abc=123'; console.log(querystring.parse(str,'&','c'));//{ 'foo=bar': '', ab: [ '=xyz', '=123' ] }
[注意]querystring.parse()方法返回的對(duì)象不繼承自 JavaScript 的 Object。 這意味著典型的 Object 方法如 obj.toString()、obj.hasOwnProperty() 等沒(méi)有被定義且無(wú)法使用
默認(rèn)情況下,查詢(xún)字符串中的百分號(hào)編碼的字符會(huì)被認(rèn)為使用了 UTF-8 編碼。 如果使用的是另一種字符編碼,則 decodeURIComponent 選項(xiàng)需要被指定
var querystring = require('querystring'); //{ w: '����', foo: 'bar' } console.log(querystring.parse('w=%D6%D0%CE%C4&foo=bar', null, null,{ decodeURIComponent: 'gbkDecodeURIComponent' }));
querystring.stringify(obj[, sep][, eq][, options])
querystring.stringify()方法是querystring.parse()方法的逆向操作,通過(guò)遍歷對(duì)象的自有屬性,從一個(gè)給定的obj產(chǎn)生一個(gè)URL查詢(xún)字符串,參數(shù)如下
obj <Object> 要序列化成一個(gè) URL 查詢(xún)字符串的對(duì)象
sep <String> 用于界定查詢(xún)字符串中的鍵值對(duì)的子字符串。默認(rèn)為 '&'
eq <String> 用于界定查詢(xún)字符串中的鍵與值的子字符串。默認(rèn)為 '='
options
encodeURIComponent <Function> 當(dāng)把對(duì)URL不安全的字符轉(zhuǎn)換成查詢(xún)字符串中的百分號(hào)編碼時(shí)使用的函數(shù)。默認(rèn)為 querystring.escape()
var querystring = require('querystring'); //'foo=bar&baz=qux&baz=quux&corge=' console.log(querystring.stringify({ foo: 'bar', baz: ['qux', 'quux'], corge: '' })); var querystring = require('querystring'); //'foo:bar;baz:qux' console.log(querystring.stringify({foo: 'bar', baz: 'qux'}, ';', ':'));
queryString模塊編碼
querystring.escape(str)
querystring.escape()方法對(duì)給定的str執(zhí)行URL百分號(hào)編碼,與encodeURIComponent方法一樣
querystring.escape()方法是供querystring.stringify()使用的,且通常不被直接使用。它之所以對(duì)外開(kāi)放,是為了在需要時(shí)可以通過(guò)給querystring.escape賦值一個(gè)函數(shù)來(lái)重寫(xiě)編碼的實(shí)現(xiàn)
var querystring = require('querystring'); console.log(encodeURIComponent('測(cè)試'));//%E6%B5%8B%E8%AF%95 console.log(querystring.escape('測(cè)試'));//%E6%B5%8B%E8%AF%95
querystring.unescape(str)
querystring.unescape() 方法對(duì)給定的 str 上的 URL 百分號(hào)編碼的字符執(zhí)行解碼
querystring.unescape()方法是供querystring.parse()使用的,且通常不被直接使用。它之所以對(duì)外開(kāi)放,是為了在需要時(shí)可以通過(guò)給querystring.unescape賦值一個(gè)函數(shù)來(lái)重寫(xiě)解碼的實(shí)現(xiàn)。
querystring.unescape()方法默認(rèn)使用JavaScript內(nèi)置的decodeURIComponent() 方法來(lái)解碼
var querystring = require('querystring'); console.log(decodeURIComponent('%E6%B5%8B%E8%AF%95'));//'測(cè)試' console.log(querystring.unescape('%E6%B5%8B%E8%AF%95'));//'測(cè)試'
Node.JS獲取GET數(shù)據(jù)
get請(qǐng)求的數(shù)據(jù)保存在URL中
http://127.0.0.1:8080/home/test?a=1&b=2 var http = require('http'); var url = require('url'); var querystring = require('querystring'); http.createServer(function(req,res){ var urlObj = url.parse(req.url); var query = urlObj.query; var queryObj = querystring.parse(query); console.log(req.url);//'/home/test?a=1&b=2' console.log(query);//'a=1&b=2' console.log(queryObj);//{ a: '1', b: '2' } }).listen(8080);
Node.JS獲取POST數(shù)據(jù)
post請(qǐng)求的數(shù)據(jù)會(huì)被寫(xiě)入緩沖區(qū)中,需要通過(guò)request的data事件和end事件來(lái)進(jìn)行數(shù)據(jù)拼接處理
var http = require('http'); var url = require('url'); var querystring = require('querystring'); http.createServer(function(req,res){ var str = ''; req.on('data', function(thunk){ str += thunk; }); req.on('end', function(){ console.log(str);//'name=a&email=b%40b.com' var queryObj = querystring.parse(str); console.log(queryObj);//{ name: 'a', email: 'b%40b.com' } });
更多關(guān)于Node.JS獲取GET,POST數(shù)據(jù)的文章請(qǐng)點(diǎn)擊下面的相關(guān)鏈接
相關(guān)文章
Node.js中文件操作模塊File System的詳細(xì)介紹
FileSystem模塊是類(lèi)似UNIX(POSIX)標(biāo)準(zhǔn)的文件操作API,用于操作文件系統(tǒng)——讀寫(xiě)目錄、讀寫(xiě)文件——Node.js底層使用C程序來(lái)實(shí)現(xiàn),這些功能是客戶(hù)端JS所不具備的。下面這篇文章就給大家詳細(xì)介紹了Node.js中的文件操作模塊File System,有需要的朋友們可以參考借鑒。2017-01-01node.js 開(kāi)發(fā)指南 – Node.js 連接 MySQL 并進(jìn)行數(shù)據(jù)庫(kù)操作
通常在NodeJS開(kāi)發(fā)中我們經(jīng)常涉及到操作數(shù)據(jù)庫(kù),尤其是 MySQL ,作為應(yīng)用最為廣泛的開(kāi)源數(shù)據(jù)庫(kù)則成為我們的首選,本篇就來(lái)介紹下如何通過(guò)NodeJS來(lái)操作 MySQL 數(shù)據(jù)庫(kù)。2014-07-07Node.js多文件Stream合并,串行和并發(fā)兩種模式的實(shí)現(xiàn)方式
這篇文章主要介紹了Node.js多文件Stream合并,串行和并發(fā)兩種模式的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10Node.js的路由、EJS模板引擎、GET和POST請(qǐng)求講解
這篇文章介紹了Node.js的路由、EJS模板引擎、GET和POST請(qǐng)求,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06Node.js實(shí)現(xiàn)簡(jiǎn)單管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Node.js實(shí)現(xiàn)簡(jiǎn)單管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09