博客
关于我
Node+express框架图片上传
阅读量:771 次
发布时间:2019-03-24

本文共 1478 字,大约阅读时间需要 4 分钟。

上传功能开发实录

1. 创建表单提交 upload.html 文件

我们需要为用户创建一个简单的图片上传表单,用户可以通过该表单上传个人头像。创建一个 upload.html 文件,内容如下:

    用户头像上传    

用户头像上传

上传头像:

2. 创建处理文件 upload.js

我们需要创建一个 upload.js 文件,作为服务器端的处理逻辑。以下是实现步骤:

1.1 引入必要的库

使用以下外部库来处理文件上传和路由:

const express = require('express');const bodyParser = require('body-parser');const formidable = require('formidable');const fs = require('fs');const path = require('path');

1.2 初始化服务器和中间件

const app = express();app.use(bodyParser.urlencoded({ extended: false }));

1.3 配置静态资源和路由

app.use(express.static(path.join(__dirname, 'upload')));// 定义路由app.get('/', (req, res) => {    res.sendFile(path.join(__dirname, 'upload.html'));});app.post('/upload', (req, res) => {    // 处理文件上传    const form = new formidable.IncomingForm();    form.parse(req, (err, fields, files) => {        // 读取上传的文件        const readStream = fs.createReadStream(files.userImg.path);                // 写入文件        const writeStream = fs.createWriteStream(            path.join(__dirname, 'upload', files.userImg.name)        );        readStream.pipe(writeStream);                // 处理上传完成后的回应        res.send(`图片已上传至 ${files.userImg.name}`);    });});

1.4 启动服务器

app.listen(3000, () => {    console.log('服务器运行中,访问地址为 http://localhost:3000');});

这样,用户可以通过浏览器访问 http://localhost:3000 进行头像上传。上传完成后,图片会被保存在 upload 目录下。

注意事项

  • filefields 的处理需要谨慎操作
  • 确保服务器端有权限写入目标目录
  • 可以在上传完成后返回图片的路径或页面跳转
  • 建议配置 funculiar 中间件进行图片处理和文件类型验证
  • 这个实现方案简单明了,适合用于图片头像上传场景,同时兼容大部分主流的浏览器。

    转载地址:http://yyokk.baihongyu.com/

    你可能感兴趣的文章
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    NLP学习笔记:使用 Python 进行NLTK
    查看>>
    NLP:使用 SciKit Learn 的文本矢量化方法
    查看>>
    Nmap扫描教程之Nmap基础知识
    查看>>
    Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
    查看>>
    NMAP网络扫描工具的安装与使用
    查看>>
    NMF(非负矩阵分解)
    查看>>
    NN&DL4.1 Deep L-layer neural network简介
    查看>>
    NN&DL4.3 Getting your matrix dimensions right
    查看>>
    NN&DL4.8 What does this have to do with the brain?
    查看>>
    No 'Access-Control-Allow-Origin' header is present on the requested resource.
    查看>>
    No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>
    No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
    查看>>
    No mapping found for HTTP request with URI [/...] in DispatcherServlet with name ...的解决方法
    查看>>
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
    查看>>
    No new migrations found. Your system is up-to-date.
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>