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如何复制文件
Mar 09 NodeJs
Nodejs 搭建简单的Web服务器详解及实例
Nov 30 NodeJs
NodeJs下的测试框架Mocha的简单介绍
Feb 22 NodeJs
搭建简单的nodejs http服务器详解
Mar 09 NodeJs
详解使用nodeJs安装Vue-cli
May 17 NodeJs
NodeJs搭建本地服务器之使用手机访问的实例讲解
May 12 NodeJs
详解NodeJs开发微信公众号
May 25 NodeJs
nodejs更新package.json中的dependencies依赖到最新版本的方法
Oct 10 NodeJs
nodejs 使用nodejs-websocket模块实现点对点实时通讯
Nov 28 NodeJs
nodejs实现UDP组播示例方法
Nov 04 NodeJs
nodejs环境使用Typeorm连接查询Oracle数据
Dec 05 NodeJs
基于NodeJS开发钉钉回调接口实现AES-CBC加解密
Aug 20 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
PHP脚本数据库功能详解(上)
2006/10/09 PHP
PHP mb_convert_encoding 获取字符串编码类型实现代码
2009/04/26 PHP
PHP关联数组的10个操作技巧
2013/01/21 PHP
destoon调用自定义模板及样式的公告栏
2014/06/21 PHP
js类 from qq
2006/11/13 Javascript
js限制textarea每行输入字符串长度的代码
2012/10/31 Javascript
nodejs开发环境配置与使用
2014/11/17 NodeJs
JavaScript中的分号插入机制详细介绍
2015/02/11 Javascript
JavaScript淡入淡出渐变简单实例
2015/08/06 Javascript
超详细的JS弹出窗口代码大全
2020/04/18 Javascript
EasyUI学习之DataGird分页显示数据
2016/12/29 Javascript
JS实现含有中文字符串的友好截取功能分析
2017/03/13 Javascript
Vue实现购物车功能
2017/04/27 Javascript
angularJS利用ng-repeat遍历二维数组的实例代码
2017/06/03 Javascript
详解微信第三方小程序代开发
2017/06/23 Javascript
BACKBONE.JS 简单入门范例
2017/10/17 Javascript
JavaScript事件对象event用法分析
2018/07/27 Javascript
浅谈vue后台管理系统权限控制思考与实践
2018/12/19 Javascript
JS中作用域以及变量范围分析
2020/07/18 Javascript
使用Pyrex来扩展和加速Python程序的教程
2015/04/13 Python
python 循环while和for in简单实例
2016/08/16 Python
浅析python递归函数和河内塔问题
2017/04/18 Python
Python实现登录接口的示例代码
2017/07/21 Python
在Qt5和PyQt5中设置支持高分辨率屏幕自适应的方法
2019/06/18 Python
基于python二叉树的构造和打印例子
2019/08/09 Python
django框架ModelForm组件用法详解
2019/12/11 Python
anaconda安装pytorch1.7.1和torchvision0.8.2的方法(亲测可用)
2021/02/01 Python
介绍一下linux文件系统分配策略
2012/11/17 面试题
药学专业大学生自荐信
2013/09/28 职场文书
电脑租赁公司创业计划书
2014/01/08 职场文书
装修致歉信
2014/01/15 职场文书
商铺门面租房协议书
2014/10/21 职场文书
党的群众路线教育实践活动总结
2014/10/30 职场文书
2016春季运动会通讯稿
2015/07/18 职场文书
应用最多的公文《通知》如何写?
2019/04/02 职场文书
劳务派遣管理制度(样本)
2019/08/23 职场文书