node.js - express無(wú)法獲取req.params值?
問(wèn)題描述
var express = require(’express’);var bodyParser = require(’body-parser’)var port = process.env.PORT || 3000var app = express()var path = require(’path’);var mongoose = require(’mongoose’)var _ = require(’underscore’)var fs = require(’fs’);var jsonParser = bodyParser.json()var urlencodedParser = bodyParser.urlencoded({ extended: false })mongoose.connect(’mongodb://localhost/meetdb’)app.set(’views’, ’./views/pages’)app.set(’view engine’, ’jade’)app.use(urlencodedParser);app.use(express.static(path.join(__dirname, ’public’)))app.listen(port)// user 相關(guān)app.post(’/user/signup’,function (req,res){ console.log(req.params) console.log(req.body)})
可以獲取到req.body,但是無(wú)法獲取到req.params。我看網(wǎng)上說(shuō)的是可以同時(shí)獲取query和body的值。
問(wèn)題解答
回答1:通常是req.params吧,來(lái)獲取路徑中的參數(shù)
回答2:據(jù)我了解,req.params 只有在參數(shù)化的路徑中的參數(shù)。你想取的是查詢字符串中的參數(shù)嗎?
查詢字符串中的參數(shù)要用 req.query.
比如
// server.js: app.post(’/user/:id’, function(req, res){console.log(’req.params: ’, req.params)console.log(’req.query: ’, req.query)console.log(’req.body: ’, req.body) })
// HTTP request:POST /user/123?foo=1&bar=2Content-Type: application/x-www-form-urlencodedaaa=1&bbb=2
這樣的請(qǐng)求,應(yīng)該是要用 req.query.foo 和 req.query.bar 來(lái)獲取 foo 和 bar 的值,最終打印出如下:
req.params: { id: ’123’ }req.query: { foo: ’1’, bar: ’2’ }req.body: { aaa: ’1’, bbb: ’2’ }
話說(shuō)這種問(wèn)題 console.log 的效率太慢,為啥不用斷點(diǎn):
看看用VSCode打斷點(diǎn)查看變量爽爆了。
回答3:/user/signup 這里 /user/signup/:aaa 你才有params
相關(guān)文章:
1. angular.js - angularjs 使用鼠標(biāo)懸停時(shí),標(biāo)簽一直閃2. angular.js - angularjs的自定義過(guò)濾器如何給文字加顏色?3. 一個(gè)走錯(cuò)路的23歲傻小子的提問(wèn)4. java - Hibernate查詢的數(shù)據(jù)是存放在session中嗎?5. 我在centos容器里安裝docker,也就是在容器里安裝容器,報(bào)錯(cuò)了?6. c++ - win764位環(huán)境下,我用GCC為什么指針占8個(gè)字節(jié),而long是4個(gè)字節(jié)?7. 在mac下出現(xiàn)了兩個(gè)docker環(huán)境8. html5 - HTML代碼中的文字亂碼是怎么回事?9. python 計(jì)算兩個(gè)時(shí)間相差的分鐘數(shù),超過(guò)一天時(shí)計(jì)算不對(duì)10. python - django 里自定義的 login 方法,如何使用 login_required()
