MySQL хранить "Неопределенную" строку в nodejs multipart / form-data? - PullRequest
0 голосов
/ 03 августа 2020
Приложение

js с сервером mysql в моем приложении Я хочу сохранить имя файла изображения одновременно с тем, как файл изображения будет сохраняться в папке моего проекта. Я использую эту multer framework для загрузки моего файла. Да, я успешно сохранил файл изображения в папке / uploads моего проекта. Но, к сожалению, MySQL не позволяет мне отправлять данные, в нем будет храниться только "неопределенная" строка. Как мы можем это исправить?

enter image description here

 прикрепленный_файл      Выберите аудиофайл   Отправить  Отменить    

приложение js

const path = require('path');
const express = require('express');
const multer = require('multer');
const ejs = require('ejs');
const bodyParser = require('body-parser');
const mysql = require('mysql');
const app = express();

const DIR = './assets/uploads/featured-img';

// Set Database Connection
const connection=mysql.createConnection({
    host:'localhost',
    user:'root',
    password:'',
    database:'nodejs_crud'
});

connection.connect(function(error){
    if(!!error) console.log(error);
    else console.log('Database Connected!')
});
 
let storage = multer.diskStorage({
    destination: function (req, file, callback) {
      callback(null, DIR);
    },
    filename: function (req, file, cb) {
      cb(null, file.fieldname + '-' + Date.now() + path.extname(file.originalname));
    }
});

let upload = multer({storage: storage});

//set view file
app.use(express.static('assets'));

//set view engine
app.set('view engine', 'ejs');

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extend: false}));

app.get('/',(req, res) => {
    let sql = "SELECT * FROM music"
    let query = connection.query(sql, (err, rows) => {
        if(err) throw err;
        res.render('music_index');
    });
});

app.post('/save',upload.single('featured_img'), function (req, res) {
    let sql = "INSERT INTO `music`(`featured_img`, `title`, `band_name`, `audio`) VALUES ('" + req.body.featured_img + "', '"+req.body.title+"', '"+req.body.band_name+"', '"+req.body.audio+"')";
    let query = connection.query(sql, (err, results) => {
        if(err) throw err;
        res.redirect('/');
    });
});

// Server Listening
const port = 3000;

app.listen(port, () => console.log(`Server started on port ${port}`));

1 Ответ

1 голос
/ 04 августа 2020

Вот пример загружаемого одного файла. Чтобы загрузить несколько файлов в одной форме, вам необходимо использовать upload.array вместо upload.single:

/ views / music_index.e js:

image

app. js:

const path = require('path');
const express = require('express');
const multer = require('multer');
const ejs = require('ejs');
const bodyParser = require('body-parser');
const mysql = require('mysql');
const app = express();
// Ensure this folder exists
const DIR = './assets/uploads/featured-img';
 
let storage = multer.diskStorage({
    destination: function (req, file, callback) {
      callback(null, DIR);
    },
    filename: function (req, file, cb) {
      cb(null, file.fieldname + '-' + Date.now() + path.extname(file.originalname));
    }
});

let upload = multer({storage: storage});
app.use(express.static('assets'));
app.set('view engine', 'ejs');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extend: false}));

app.get('/',(req, res) => {
    res.render('music_index');
});

app.post('/save',upload.single('featured_img'), function (req, res) {    
    let sql = "INSERT INTO `music`(`featured_img`, `title`, `band_name`, `audio`) VALUES ('" + req.file.path + "', '"+req.body.title+"', '"+req.body.band_name+"', '"+req.body.audio+"')";
    console.log(sql);
});

const port = 3000;

app.listen(port, () => console.log(`Server started on port ${port}`));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...