我在使用Cloudinary API上传图片时遇到问题。
我的应用程序在Heroku上运行。我将Node用于后端。该应用程序运行良好,直到用户尝试发布图像为止。然后,我收到以下错误消息:
无效签名********************************************。串到 签名-'timestamp = **********。
我在另一个应用程序中使用了相同的设置,并且工作正常。我已经跟踪了一些有关该问题的堆栈溢出线程,但是并没有得到我所理解的有用答案。
我在Heroku中设置环境变量的方式与在其他应用程序中设置的方式相同,并且可以运行。我还在我的package.json文件中安装了Cloudinary和Multer软件包。
有什么想法我在这里做错了吗?
下面是我的代码:
var multer = require('multer');
var storage = multer.diskStorage({
filename: function(req, file, callback) {
callback(null, Date.now() + file.originalname);
}
});
var imageFilter = function (req, file, cb) {
// accept image files only
if (!file.originalname.match(/\.(jpg|jpeg|png|gif)$/i)) {
return cb(new Error('Only image files are allowed!'), false);
}
cb(null, true);
};
var upload = multer({ storage: storage, fileFilter: imageFilter});
var cloudinary = require('cloudinary');
cloudinary.config({
cloud_name: 'digi9mjbp',
api_key: process.env.CLOUDINARY_API_KEY,
api_secret: process.env.CLOUDINARY_API_SECRET
})
router.post("/", middleware.isLoggedIn, upload.single('image'),
function(req, res) {
cloudinary.v2.uploader.upload(req.file.path, function(err,result){
if(err){
req.flash("error", err.message);
return res.redirect("back");
}
// add cloudinary url for the image to the topic object under image
property
req.body.topic.image = result.secure_url;
//add image's public_id to topic object
req.body.topic.imageId = result.public_id;
// add author to topic
req.body.topic.author = {
id: req.user._id,
username: req.user.username
};
Topic.create(req.body.topic, function(err, topic){
if (err) {
req.flash('error', err.message);
return res.redirect('back');
}
res.redirect('/topics/' + topic.id);
});
});
});