nodejs写接口实现图片上传回显(三)

1. 过程简介

(1)页面用formData上传图片文件
(2)接口配置multer中间件,解析存储图片文件
(3)接口返回图片地址,回显

2. 代码

2.1 前端文件上传

//结构
<div class="imgUpload">
      <div class="input">
        <input type="file" accept=".jpg,.png" ref="uploadBox" v-show="false" @change="imgChange">
      </div>
      <div style="display: flex;align-items: center;width: 100%;">
        <div style="margin-right: 20px;">
          <el-button type="primary" size="mini" @click="imgSend">上传</el-button>
        </div>
        <div>
          <img src="" alt="">
        </div>
      </div>
    </div>
//js
    // 图片上传
    imgSend () {
      this.$refs.uploadBox.click()
    },
    // 选择要上传的图片更替
    imgChange () {
      const target = this.$refs.uploadBox.files[0]
      const formDate = new FormData()

      formDate.append('image', target)
      interfaces.sendImg(formDate).then(res => {
        console.log(res, '图片上传结果')
        //回显
        document.querySelector('img').src = res.data.url
      }).catch(err => {
        console.log(err, '图片上传错误')
      })
    },

2.2 接口

2.2.1 multer中间件配置
const multer = require('multer'); // 用于处理文件上传
const path = require('path');//获取当前地址模块

app.use('/imgUploads', express.static(path.join(__dirname, 'imgUploads')));// 设置静态文件目录

// 配置 multer 中间件来处理文件上传
const storage = multer.diskStorage({
    // 设置图片存储的位置
    destination: (req, file, cb) => {cb(null, './imgUploads');},
    // 设置图片的名字
    filename: (req, file, cb) => {cb(null, file.originalname);},
});

const upload = multer({ storage });

//post 图片上传
app.post('/imgUpload', upload.single('image'), (request, response) => {
    const data = {
        message: '图片上传成功!',
        //图片的地址
    	url:`http://192.168.158.156:9000/imgUploads/${request.file.filename}` 
    }
    const visitorIP = request.headers['x-forwarded-for'] || request.connection.remoteAddress;
    console.log(data, '获取的请求参数');
    console.log(visitorIP, '请求者的地址');
    response.status(200).send(data)
})
2.2.2 上传到指定文件夹

在这里插入图片描述

2.3 图片回显

在这里插入图片描述

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Node.js中编接口的一种常见方式是使用Express框架。以下是一个简单的示例: ```javascript const express = require('express'); const app = express(); // 添加中间件处理跨域请求 app.use(function(req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS'); res.header("Access-Control-Allow-Headers", "X-Requested-With"); res.header('Access-Control-Allow-Headers', 'Content-Type'); next(); }); // GET方式监听/login请求 app.get('/login', (req, res) => { // 在这里你的处理逻辑 res.send('返回登录结果'); }); // 监听特定端口 app.listen(3000, () => { console.log('服务器运行在3000端口'); }); ``` 你可以根据自己的需要在接口处理函数中添加具体的逻辑。这个示例中使用了Express框架,通过app对象可以添加不同的路由和中间件来处理不同的接口请求。其中,使用app.get表示监听GET请求的/login接口,并在处理函数中返回登录结果。你可以根据需要修改接口的路径、请求方式和返回结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [用nodejs一个简单的接口](https://blog.csdn.net/weixin_44785209/article/details/121268183)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [如何用Nodejs接口](https://blog.csdn.net/qqq6654066/article/details/122607749)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值