我使用vue3,vuex,express.js和mysql。在下面的路由器get方法中,我调用"console.log(req.body)“并显示"object Object",调用"console.log(req.body.userid)”并显示“未定义”。
router.get('/',async function(req,res){
const userId = req.body.userid;
console.log("req body is: "+req.body);
console.log("req.body.userid is: "+req.body.userid);
.....
}
在下面的方法中,我将userID值作为json对象传递。我调用"console.log("post userid:"+userinfo.userid);“并显示正确的值"1";
async getsp(){
var userinfo = JSON.parse(localStorage.getItem('user'));
console.log("post userid: "+userinfo.userid);
var userid = userinfo.userid;
var obj = {userid};
return await axios.get('//localhost:8081/getSp',obj)
.then(...)
},
在我使用的主体解析器的主路由器文件中,文件上下文如下:
require("dotenv").config();
const express = require('express');
const bodyParser = require('body-parser');
var cors = require('cors');
const signup = require('./userSignUp');
const login = require('./userLogin');
const createEvsp = require('./createEvsp');
const getSp = require('./getSp');
//const createFile = require('./createFile');
const app = express();
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json())
app.use(cors())
app.use(express.json());
app.use(
express.urlencoded({
extended: true
})
);
app.use("/signup",signup);
app.use("/dologin",login);
app.use("/createEvsp",createEvsp);
app.use("/getSp",getSp);
//app.use("/createFile",createFile);
app.listen(8081,function () {
console.log('Server running at 8081 port');
});
发布于 2021-02-22 08:28:35
问题在于对HTTP方法的理解和express的工作方式
为了解决这个问题,需要使用express中间件/:userid
来访问使用req.params.userid
的参数
根据http标准,我们通常使用POST请求来发送数据。堆栈中有一个很好的答案,Information about Get HTTP Request
Sayf-Eddine
https://stackoverflow.com/questions/66311713
复制