账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    express中间件Multer文件存放地址问题
    • 2019-07-01 00:00
    • 10
    60
    0

    问题描述

    在本地开发版本中上传的图片使用相对路径../../view/src/assets/img,正常可以访问

    但是通过webpack打包,项目上线后这个地址就不行了,这个地址是打包之前的前端代码地址。

    相关代码

    var storage = multer.diskStorage({
        //设置上传后文件路径,uploads文件夹会自动创建。
           destination: function (req, file, cb) {
               cb(null, '../../view/src/assets/img')
          }, 
        //给上传文件重命名,获取添加后缀名
         filename: function (req, file, cb) {
             var fileFormat = (file.originalname).split(".");
             cb(null, file.fieldname + '-' + Date.now() + "." + fileFormat[fileFormat.length - 1].toLowerCase());
         }
    }); 

    打包之后的图片文件都是放在static/img/ 下面项目使用的图片也是这个目录的,应该怎么修改这个地址让线上的项目访问到用户上传的文件呢?

    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 10 元积分
        全部回答
    • 0
    • 振翅的蚂蚁 普通会员 1楼

      在使用Express中间件 Multer 时,文件的存放地址可能会有所不同。以下是一些可能的原因:

      1. 环境设置:如果你在开发环境(如本地开发环境)中使用 Multer,那么文件的存放地址通常是在项目的根目录下。例如,如果你的项目名为 "my-app",那么文件的存放地址可能是在 "my-app" 目录下。

      2. 中间件设置:在使用 Multer 时,你可能需要在中间件的配置文件中设置文件的存放地址。例如,你可能在中间件的配置文件中设置 "uploadDir": "/path/to/upload/directory",这样,所有的上传请求都会被发送到指定的目录。

      3. 配置错误:如果你在运行项目时出现了错误,那么可能是由于配置错误导致的。你需要检查你的中间件配置文件,确保文件的存放地址是正确的。

      如果你不确定具体的情况,你可以查看 Multer 的官方文档,或者尝试在你的项目中直接运行你的应用,看看文件的存放地址是否正确。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部