ajax +NodeJS 实现图片上传实例
网络编程 2021-07-04 18:32www.168986.cn编程入门
本篇文章主要介绍了ajax +NodeJS 实现图片上传实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
前台用jquery的ajax发请求,后台用NodeJS 的multer模块实现图片上传。这个demo给我的感悟是一定要自己能实现出来,而不是看了别人写好就直接“拿来”用
note(注意)
大家先在public目录下创建一个名为uploads的文件夹,这个文件夹是用来保存你上传过的图片
安装multer模块:
npm i -S multer
code(代码)
1.app.js
const express = require('express'); const multer = require('multer'); const path = require('path'); const app = express(); //所有请求过来,都去项目当前的public目录下寻找所请求的文件,找到就返回 app.use(express.static('./public')); //选择diskStorage存储 const storage = multer.diskStorage({ destination: function (req, file, cb) { cb(null, path.resolve('public/uploads')); }, filename: function (req, file, cb) { cb(null, Date.now() + path.extname(file.originalname));//增加了文件的扩展名 } }); const upload = multer({storage: storage}); app.post('/profile', upload.single('avatar'), function(req, res, next) { res.send({ err: null, //filePath:就是图片在项目中的存放路径 filePath: 'uploads/' + path.basename(req.file.path) }); }); app.listen(3000, function () { console.log("app is listening 3000 port"); });
2.index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script type="text/javascript" src="js/jquery-3.1.0.min.js"></script> </head> <body> <form class="form-horizontal" enctype='multipart/form-data' method='post' action='javascript:;'> <input type="file" id="choose"/> <button onclick="handle()">上传</button> <img class="newImg"/> </form> <script> function handle() { //获取上传的File对象,此处是一张图片对象 let file = document.getElementById("choose").files[0]; let formData = new FormData(); formData.append("avatar", file);//设置key为avartar,value为上述的File对象 $.ajax({ type: 'POST', url: '/profile', data: formData, processData: false, suess: function (data) { $(".newImg").attr("src", data.filePath);//上传成功则图片显示 }, error: function (err) { console.log(err.message); } }) } </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 机械手焊接机器人编程 机械手焊接设备编程
- vb数据库编程实例,vb做数据库
- tiobe世界编程语言排行榜,全球编程语言排行
- 成都java编程培训 成都it编程培训中心
- 编程基础培训,编程基础知识培训
- flash游戏编程基础教程,flash游戏开发教程
- 不会英语能学编程吗 不会英语可以学程序员吗
- 爱心代码编程C语言 爱心代码编程c语言公式
- c语言编程学习入门 c语言编程快速入门
- 西门子plc编程培训 西门子plc编程培训班
- 哪里可以学编程 台州哪里可以学编程
- 少儿编程哪个好 少儿编程哪个品牌好
- 编程是什么意思,图形编程是什么意思
- c语言编程软件下载,c语言编程软件在哪下载
- java编程软件下载,java编程下载手机版
- ug编程培训学校,ug编程培训教程