vue项目上传图片到Linux服务器并预览

14 篇文章 0 订阅
4 篇文章 0 订阅

上传

.vue

<form action="/api/upload" method="post" enctype="multipart/form-data">
      <input type="file" name="logo">
      <input type="submit" value="提交">
    </form>

file.js

const express = require('express')
const router = express.Router()
const db = require('./db.js')
const Tools = require('../utils/index');
const multer = require('multer');//upload
//设置上传地址/jane-file/img下 , Tools.getNowTimeStamp()是获取当天的日期
const storage = multer.diskStorage({
  destination: `/jane-file/img/${Tools.getNowTimeStamp()}`,
  filename: function (req, file, cb) {
    cb(null, file.originalname);
  }
});
let upload = multer({
  storage: storage
});
//上传到服务器并将图片的地址保持到数据库中
router.post('/upload', upload.single('logo'), (req, res, next)=> {
  let sql = `INSERT INTO file(filename,path,type,size) VALUES 
  (${JSON.stringify(req.file.filename)},${JSON.stringify(req.file.path)},
  ${JSON.stringify(req.file.mimetype)},${JSON.stringify(req.file.size)})`;
  db.query(sql,(err,rows)=>{
    if(err){
      res.send(err)
    }else{
      let result = {
        code:0,
        message:'OK',
        data:rows,
        fileInfo:req.file,
        status:true
      };
      res.send(result);
    }
  });
});
//获取所有图片
router.use('/getFileList',(req,res)=>{
  let sql = `SELECT * FROM file`;
  db.query(sql,(err,rows)=>{
    if(err){
      req.send(err)
    }else{
      let result = {
        code:0,
        message:'OK',
        data:rows,
        status:true
      }
      res.send(result);
    }
  })
})
module.exports = router;
  • 注意name一定要相等
    在这里插入图片描述

预览

配置nginx

    # nginx.conf
	  http {
	    # others
	    server {
	        listen       8088 ssl;
	        server_name  localhost;
	        root         /;
	
	        ssl_certificate      /jane-soft/https/2426128_www.zhangxiaojuan.club.pem;
	        ssl_certificate_key  /jane-soft/https/2426128_www.zhangxiaojuan.club.key;
	
	        ssl_session_cache    shared:SSL:1m;
	        ssl_session_timeout  5m;
	
	        ssl_ciphers  HIGH:!aNULL:!MD5;
	        ssl_prefer_server_ciphers  on;
	
	        # Load configuration files for the default server block.
	        include /etc/nginx/default.d/*.conf;
	
	        error_page 404 /404.html;
	            location = /40x.html {
	        }
	
	        error_page 500 502 503 504 /50x.html;
	            location = /50x.html {
	        }
	    }
    }

配置成功后,通过服务器地址https://47.XXX.XXX.87:8088/jane-file/images/2019-7-17/5ac1ba75-804c-4e22-9744-af4f789e71fe.png即可访问到服务器上的文件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值