ajax +NodeJS 实现图片上传实例


Posted in NodeJs onJune 06, 2017

前台用jquery的ajax发请求,后台用NodeJS 的multer模块实现图片上传。这个demo给我的感悟是一定要自己能实现出来,而不是看了别人写好就直接“拿来”用

ajax +NodeJS 实现图片上传实例

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,
      success: function (data) {
        $(".newImg").attr("src", data.filePath);//上传成功则图片显示
      },
      error: function (err) {
        console.log(err.message);
      }
    })
  }
</script>
</body>
</html>

demo地址在这

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
Nodejs抓取html页面内容(推荐)
Aug 11 NodeJs
nodejs微信公众号支付开发
Sep 19 NodeJs
nodejs搭建本地服务器并访问文件的方法
Mar 03 NodeJs
nodejs入门教程五:连接数据库的方法分析
Apr 24 NodeJs
Nodejs搭建wss服务器教程
May 24 NodeJs
NodeJS实现图片上传代码(Express)
Jun 30 NodeJs
nodejs开发微信小程序实现密码加密
Jul 11 NodeJs
nodejs实现OAuth2.0授权服务认证
Dec 27 NodeJs
Nodejs连接mysql并实现增、删、改、查操作的方法详解
Jan 04 NodeJs
nodejs中用npm初始化来创建package.json的实例讲解
Oct 10 NodeJs
nodejs使用node-xlsx生成excel的方法示例
Aug 22 NodeJs
Nodejs实现图片上传、压缩预览、定时删除功能
Oct 25 NodeJs
详解Nodejs之静态资源处理
Jun 05 #NodeJs
nodejs集成sqlite使用示例
Jun 05 #NodeJs
详解nodeJS之二进制buffer对象
Jun 03 #NodeJs
深入理解Nodejs Global 模块
Jun 03 #NodeJs
nodejs socket实现的服务端和客户端功能示例
Jun 02 #NodeJs
NodeJs使用Mysql模块实现事务处理实例
May 31 #NodeJs
基于nodejs 的多页面爬虫实例代码
May 31 #NodeJs
You might like
Dedecms常用函数解析
2008/02/01 PHP
PHP 巧用数组降低程序的时间复杂度
2010/01/01 PHP
php更新mysql后获取影响的行数发生异常解决方法
2013/03/28 PHP
基于HBase Thrift接口的一些使用问题及相关注意事项的详解
2013/06/03 PHP
php安装xdebug/php安装pear/phpunit详解步骤(图)
2013/12/22 PHP
php中自定义函数dump查看数组信息类似var_dump
2014/01/27 PHP
php根据年月获取季度的方法
2014/03/31 PHP
jQuery选择没有colspan属性的td的代码
2010/07/06 Javascript
JavaScript 函数replace深入了解
2013/03/14 Javascript
jQuery获取和设置表单元素的方法
2014/02/14 Javascript
javascript setinterval 的正确语法如何书写
2014/06/17 Javascript
JavaScript日期类型的一些用法介绍
2015/03/02 Javascript
关于javascript中dataset的问题小结
2015/11/16 Javascript
浅析在javascript中创建对象的各种模式
2016/05/06 Javascript
jQuery Ajax和getJSON获取后台普通json数据和层级json数据用法分析
2016/06/08 Javascript
Angular2学习笔记——详解NgModule模块
2016/12/02 Javascript
Angular 4依赖注入学习教程之Injectable装饰器(六)
2017/06/04 Javascript
微信小程序全局变量改变监听的实现方法
2019/07/15 Javascript
关于vue项目中搜索节流的实现代码
2019/09/17 Javascript
javascript设计模式 ? 代理模式原理与用法实例分析
2020/04/16 Javascript
详解Howler.js Web音频播放终极解决方案
2020/08/23 Javascript
tensorflow: 查看 tensor详细数值方法
2018/06/13 Python
python中selenium操作下拉滚动条的几种方法汇总
2019/07/14 Python
PyTorch中常用的激活函数的方法示例
2019/08/20 Python
Python 3 使用Pillow生成漂亮的分形树图片
2019/12/24 Python
DataFrame.groupby()所见的各种用法详解
2020/06/14 Python
windows支持哪个版本的python
2020/07/03 Python
俄罗斯街头服装品牌:Black Star Wear
2017/03/01 全球购物
护理学中专毕业生求职信
2013/11/11 职场文书
毕业生求职找工作的自我评价范文
2013/11/27 职场文书
化妆品促销方案
2014/02/24 职场文书
2014个人反腐倡廉思想汇报
2014/09/15 职场文书
小学少先队辅导员述职报告
2015/01/10 职场文书
2016应届毕业生自荐信范文
2016/01/28 职场文书
描述鲁迅的名言整理,一生受用
2019/08/08 职场文书
《艾尔登法环》1.03.3补丁上线 碎星伤害调整
2022/04/06 其他游戏