РЕШЕНО СПАСИБО @Patrick Evans
Я создаю свой собственный веб-проект и мне нужна помощь. На веб-сайте клиенту предлагается загрузить фотографию лица. Затем, когда клиент нажимает кнопку «загрузить», его фотография отправляется с запросом к api «face ++», который возвращает подробности о фотографии, такие как эмоции и пол, на другой странице ejs. На новой странице клиент видит свою фотографию, а ниже - сведения о своей фотографии.
Работает нормально, но когда клиент возвращается на домашнюю страницу и выбирает другую новую фотографию, затем нажимаетзагрузить, он видит свою новую фотографию, которую он выбрал, но получает те же данные, что были на последней фотографии (подробности от лица ++ api).
Я использую следующее:
- express.
- unirest для выполнения запроса к api "face ++".
- для получения URL-адреса и использования URL-адреса в запросе face ++ (URL-адрес представляет фотографию клиента).
- multer для хранения на локальном диске.
Когда я распечатываю детали, которые возвращаются из API "face ++", в функции "requestFromApi.end ()",я уже заметил, что детали не изменились по сравнению с предыдущим запросом, но я заметил в облачной среде, что была загружена другая фотография.
Я приложил свой код 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';
});