图片上传实现步骤
创作时间:
作者:
@小白创作中心
图片上传实现步骤
引用
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模块接收并处理上传的图片数据,最后将图片保存到指定的目录并返回图片的访问路径。
热门推荐
湛江春节探秘:调顺网龙里的岭南年味
李嘉诚式投资:助配偶财富增值
任泽平谈家庭经济学:配偶职业如何影响家财?
提升配偶职场竞争力的五大秘籍
五分钟冥想:快速恢复精力的科学方法
高并发、多线程+学习力=职场超人?
户外电源:自由探索的能源保障
封神榜各大战役人物以及实力排名——冀州之战
2024医学新知丨神经损伤的治疗进展:促进神经修复与功能恢复
周围神经损伤的诊断与治疗
剖腹产后腿部神经损伤的处理方法
军事智能化边缘计算有哪些应用场景?
一文搞懂移动止盈止损什么意思?
交易如何设置止损点
古代易容术的奥秘:真假难辨的艺术
心理学名词:投射和移情的不同
卡西尼号:揭秘土星系统的“超级侦探”
卡西尼号揭秘:土星环的年龄、构成与消失之谜
卡西尼号的辉煌谢幕:土星探测的伟大历程
探索中国古代宫廷的嫔妃文化
职场道歉技巧:维护团队和谐的关键
粉丝互动率差?评论自动回复+表情话术,用户粘性提升80%
看不懂表情包,就没法跟年轻人愉快交流了?
数字时代表情符号的使用与沟通技巧:让交流更生动有趣的指南
元宵节邂逅冰雪世界:哈尔滨冰雪大世界游玩全攻略
《封神演义》的四大伯侯:东伯姜桓楚、北伯崇候虎、西伯姬昌、南伯鄂崇禹
《封神演义》的四大伯侯是谁?四大伯侯的结局分别是什么?
九一八事变:勿忘国耻,吾辈自强
北斗导航新突破:从“追赶者”到“领跑者”
双十一新手司机如何避免导航坑?