Nest接收AVue上传图片文件

1 篇文章 0 订阅

前端用的是avue组件库(对elementUI进行的二次封装),后端是NestJS

1.添加表单组件

  • <avue-crud>option.column添加对应的上传配置
  • type: 'upload',//上传
  • listType: 'picture-img',//上传图片
  • row: true,//占一行
  • width: 120,//图片宽度
  • action: '/upload',//上传地址
  • 在这里插入图片描述
  • 在这里插入图片描述

配置axios

//main.ts
const http = axios.create({
  baseURL: "http://localhost:3000"
});
Vue.prototype.$http = http;//vue的axios
Vue.prototype.$httpajax = http;//avue的axios

已经能上传了,但是是404
在这里插入图片描述

NestJS配置upload路径

//app.controller.ts
  @Post('/upload')
  @UseInterceptors(FileInterceptor('file')) //使用上传拦截器,取到前端上传的文件名
  async upload(@UploadedFile('file') file) {
    return {
      url: `http://localhost:3000/uploads/${file.filename}`,
    };
  }

保存上传文件

//app.module.ts的@Module中导入模块
    MulterModule.register({
      dest: 'uploads',
    })

配置完会生成uploads文件
在这里插入图片描述
在这里插入图片描述

Nest配置静态文件托管

//main.ts
  const app = await NestFactory.create<NestExpressApplication>(AppModule); //app基于NestExpressApplication的应用
  app.useStaticAssets('uploads', {
    prefix: '/uploads',
  }); //配置静态文件

完成

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 17
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值