node.js - express無法獲取req.params值?
問題描述
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 相關app.post(’/user/signup’,function (req,res){ console.log(req.params) console.log(req.body)})
可以獲取到req.body,但是無法獲取到req.params。我看網上說的是可以同時獲取query和body的值。
問題解答
回答1:通常是req.params吧,來獲取路徑中的參數
回答2:據我了解,req.params 只有在參數化的路徑中的參數。你想取的是查詢字符串中的參數嗎?
查詢字符串中的參數要用 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
這樣的請求,應該是要用 req.query.foo 和 req.query.bar 來獲取 foo 和 bar 的值,最終打印出如下:
req.params: { id: ’123’ }req.query: { foo: ’1’, bar: ’2’ }req.body: { aaa: ’1’, bbb: ’2’ }
話說這種問題 console.log 的效率太慢,為啥不用斷點:
看看用VSCode打斷點查看變量爽爆了。
回答3:/user/signup 這里 /user/signup/:aaa 你才有params
相關文章:
1. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
