图片上传实现步骤
创作时间:
作者:
@小白创作中心
图片上传实现步骤
引用
CSDN
1.
https://blog.csdn.net/hpxjiayou/article/details/145061144
本文将详细介绍如何实现图片上传功能,包括后端使用Express框架和前端使用React框架的具体实现步骤。通过本文的学习,读者可以掌握图片上传功能的实现方法,为开发相关应用提供参考。
后端实现步骤
- 安装multiparty第三方模块,用于接收客户端上传的图片数据
//使用npm安装
npm install multiparty
//使用yarn安装
yarn add multiparty
导入multiparty模块,定义一个图片上传的路由(上传方式必须是post请求)
在项目目录下新建一个文件夹,作用是存放客户端上传过来的文件,配置静态资源访问目录
//导入multiparty模块
var multiparty = require("multiparty")
router.post('/uploadimg',(req,res)=>{
//定义一个multiparty类型的对象,接收客户端上传的数据
let form = new multiparty.Form()
//为表单对象定义一个上传文件的目标路径
form.uploadDir='upload'
//接收上传的文件
form.parse(req,(err,a,imgData)=>{
//可以将三个参数打印查看类型,其中imgData存放的是图片的信息
//console.log(err);
//console.log(a);
//console.log(imgData);
//将图片路径返回到客户端
res.send({
code:200,
path:"http://localhost:3000/"+imgData.file[0].path
})
})
})
前端实现步骤
前端使用了组件库实现图片上传的效果,需要先安装antd组件库,注意要安装与官网相同的版本
npm install antd@5.23.0
import { Button, message, Upload } from 'antd';
export default function UploadImg() {
const props = {
//发到后台的文件参数名
name: 'file',
//上传的地址
action: 'http://localhost:3000/uploadimg',
//设置上传的请求头部,IE10 以上有效
headers: {
authorization: 'authorization-text',
},
//上传文件改变时的回调,上传每个阶段都会触发该事件
onChange(info) {
//file是当前操作的文件对象
if (info.file.status !== 'uploading') {
//上传成功
//resopnse包含后端返回的数据
console.log(info.file.response,"111");
}
if (info.file.status === 'done') {
message.success(`${info.file.name} file uploaded successfully`);
} else if (info.file.status === 'error') {
//上传失败
message.error(`${info.file.name} file upload failed.`);
}
},
};
return <>
<Upload {...props}>
<Button>上传图片</Button>
</Upload>
</>
}
通过以上步骤,可以实现一个简单的图片上传功能。前端通过antd组件库实现图片上传的界面和交互,后端通过multiparty模块接收并处理上传的图片数据,最后将图片保存到指定的目录并返回图片的访问路径。
热门推荐
王者荣耀如何查看他人隐藏战绩?如何获取完整战绩信息?
宋代女性词人的传奇一生:李清照
车管所的办公软件有哪些
宁波牌照的办理流程是什么?在办理牌照时有哪些关键步骤和注意事项?
黑格尔的哲学观点是什么?详细解释
C语言如何用二进制表示-1
C语言中-1的二进制表示:补码表示法详解
绝不能错过!五部顶级美剧推荐,多元题材让人欲罢不能
新手购买跑车有哪些推荐?
统计学专业平均工资的地域差异有多大?
生物安全知识培训课件
合工大、安大、安师大、安农大、合大等院校招生计划公布
如何选择国际支付方式
心肌缺血会整天背痛吗
色彩搭配与照明设计:打造舒适宜人的客厅氛围
先天八卦数理的寓意
劳务合同中的辞职问题:是否需要提前通知雇主?
解决目录或文件夹创建失败的常见原因及 troubleshooting 方法
生辰八字的含义及算法 生辰八字命运解析方法
戒烟会导致抑郁么?
数读“十四五”① 从五年规划看长三角41城“求同存异”
秋天钓鱼技巧:掌握最佳时间与饵料选择提升上鱼率
钓鱼的黄金时期:掌握时间,轻松捕获丰收
会员权益页面设计指南:让用户清晰感知会员价值
怎样备份电脑系统镜像文件?轻松无忧的方案
如何把旧电脑的软件转移到新电脑?三种实用迁移方法详解
connect to和connect with的区别 有哪些用法例句
C语言如何从指定列读取文件
除了橙子外,还有哪些食物富含维生素C?营养师告诉你
中介“业主”玩转新房交付,成小区红人