zoukankan      html  css  js  c++  java
  • 博客项目实战6 文件上传

      // 选择文件上传控件
        var file = document.querySelector('#file');
        var preview = document.querySelector('#preview');
        file.onchange = function() {
            //1 创建文件读取对象
            var reader = new FileReader();
            // 用户选择的文件列表
            // console.log(this.files[0]);
            // 2 读取文件
            reader.readAsDataURL(this.files[0]);
            // 3 监听 onload 事件
            reader.onload = function() {
                console.log(reader.result);
                //将文件读取的结果显示在页面中
                preview.src = "" + reader.result;
            }
     
    // 引入模块 
    const formidate = require('formidable');
    const path = require('path');
    const { Article } = require('../../model/acticle');
    module.exports = (req, res) => {
        // 1. 创建表单解析对象
        const form = new formidate.IncomingForm();
        // 2. 配置上传文件的上传位置
        form.uploadDir = path.join(__dirname, '../', '../', 'public', 'uploads');
        // 3 保留上传文件的后缀
        form.keepExtensions = true;
        // 4 解析表单
        form.parse(req, async(err, fields, files) => {
            // 1 err 错误对象 如果表单解析是不 err 里面存储错误信息 如果解析成功 err 将会是 null
            // 2 fields 对象类型 保存普通表单数据
            // 3 files 对象类型 保存了和上传文件相关的数据
            // console.log(files.cover.path.split('public')[1]); 
            // res.send(files.cover.path.split('public')[1]);
            await Article.create({
                title: fields.title,
                author: fields.author,
                publishDate: fields.publishDate,
                cover: files.cover.path.split('public')[1],
                content: fields.content
            });

            // 添加成功  重定向到列表页
            res.redirect('/admin/article');
        })
    }
  • 相关阅读:
    SSH防止超时的设置
    vuejs中v-bind绑定class时的注意事项
    js常用到的方法积累
    主流浏览器以及系统的判断
    理解Javascript的状态容器Redux
    可伸缩架构简短系列
    在Node.js中使用RabbitMQ系列一 Hello world
    在Node.js中使用RabbitMQ系列二 任务队列
    Javascript中的async await
    公钥,私钥和数字签名
  • 原文地址:https://www.cnblogs.com/ericblog1992/p/13121206.html
Copyright © 2011-2022 走看看