我刚接触过Dynamodb。我已经创建了一个DynamoDB表。通过使用dynamodb-npm,为了验证,我使用了joi。我很困惑,也面临着几个问题。首先,当我检查我的AWS‘Dynamodb仪表板时,我没有看到内容和标签项,即使它在我的模式中,

。然后,我试图使用邮递员将数据发布到我的博客数据库。

)。但是我遇到了这样的错误:ValidationException: One or more parameter values were invalid: Missing the key email in the item。
这是我的dynamoDb安装
var dynamo = require("dynamodb");
const Joi = require("joi");
dynamo.AWS.config.update({
accessKeyId: "AKIAIBJS4SX3SWW**",
secretAccessKey: "8O1dsZrIM43q8OF4kO/lMToW**",
region: "us-east-1"
});
var BlogPost = dynamo.define("BlogPost", {
hashKey: "email",
rangeKey: "title",
schema: {
email: Joi.string().email(),
title: Joi.string(),
content: Joi.binary(),
tags: dynamo.types.stringSet()
}
});
dynamo.createTables(function(err) {
if (err) {
console.log("Error creating tables: ", err);
} else {
console.log("Tables has been created");
}
});
module.exports = BlogPost;这是我的特快服务器
const express = require("express");
const app = express();
const BlogPost = require("./db");
app.post("/post", async (req, res, next) => {
try {
const logs = new BlogPost(req.body);
const entry = await logs.save();
res.json(entry);
} catch (error) {
if (error.name === "ValidationError") {
res.status(422);
}
next(error);
}
});
const port = process.env.PORT || 5000;
app.listen(port, () => console.log(` App is listening at port ${port}!`));发布于 2020-04-08 14:21:30
您的req.body不包括email属性,或者该属性是空字符串。
为您的快速服务器应用body-parser,如下所示:
...
var bodyParser = require('body-parser');
const app = express();
// parse application/json
app.use(bodyParser.json())
...https://stackoverflow.com/questions/61094797
复制相似问题