感谢@Patrick Evans
我正在创建自己的Web项目,我需要一些帮助。 在网站上,要求客户上传一张脸部照片。 然后,当客户按下“上传”按钮时,他的照片将发送到“ face ++” api的请求,该API在另一个ejs页面上返回有关照片的详细信息,例如情感和性别。客户在新页面上看到他的照片,下面是他的照片的详细信息。
工作正常,但是当客户返回首页并选择其他新照片,然后按上载时,他会看到自己选择的新照片,但得到的细节与上一次相同照片(来自face ++ api的详细信息)。
我使用以下内容:
当我打印出从“ face ++” api返回的详细信息时,在“ requestFromApi.end()”函数中,我已经注意到详细信息与先前的请求相比没有更改,但是我确实在cloudinary上注意到上传了另一张照片。
我附加了我的app.js代码。
非常感谢您的帮助:)
var unirest = require("unirest");
var requestFromApi = unirest("POST", "https://faceplusplus-
faceplusplus.p.rapidapi.com/facepp/v3/detect");
var cloudinary = require("cloudinary").v2;
const express = require('express');
const multer = require('multer');
const app = express();
const path = require("path");
var bodyParser = require("body-parser")
app.use(bodyParser.json({ limit: '50mb' }));
app.use(bodyParser.urlencoded({ // to support URL-encoded bodies
limit: '50mb',
extended: true
}));
app.set("view engine", "ejs");
cloudinary.config({
cloud_name: 'dkqvnprcj',
api_key: '756886954695832',
api_secret: 'you know i cant give you that...'
});
app.get("/", function (req, res) {
res.render("FaceApp.ejs");
});
// SET STORAGE
var storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, 'uploads')
},
filename: function (req, file, cb) {
cb(null, file.fieldname + '-' + Date.now() +
path.extname(file.originalname));
}
})
var upload = multer({ storage: storage })
app.post('/upload', upload.single('photo'), (req, res) => {
if (req.file) {
cloudinary.uploader.upload(req.file.path, function (error, result) {
//console.log(req.file);
let result_ = result;
let url = result.url;
//console.log(url)
requestFromApi.query({
return_attributes: "gender,age,smiling,facequality,eyestatus,emotion,ethnicity,beauty,skinstatus",
image_url: url
});
requestFromApi.headers({
"x-rapidapi-host": "faceplusplus-faceplusplus.p.rapidapi.com",
"x-rapidapi-key": "9dd7fa4266mshf1c29ba307ecf2dp1bb1dajsna431d00b6273",
"content-type": "application/x-www-form-urlencoded"
});
requestFromApi.form({});
requestFromApi.end(function (result) {
if (result.error) throw new Error(result.error);
else {
let detailsFromApi = JSON.parse(JSON.stringify(result.body.faces));
detailsFromApi.forEach(function (element) {
console.log(element);
});
res.render("image",{result_ : result_, detailsFromApi:detailsFromApi});
}
});
});
}
else throw 'error';
});
答案 0 :(得分:0)
感谢@Patrick Evans [1]:https://stackoverflow.com/users/560593/patrick-evans
我必须确保在每个Post请求中都调用“ Unirest”,而不仅仅是在执行开始时调用。