angular2+nodejs实现图片上传功能


Posted in NodeJs onMarch 27, 2017

在使用angular2进行图片上传的时候,遇到了各种各样的问题。在多番尝试之后最终成功上传图片,下面将我的方法分享给大家:

nodejs 后台代码

var express = require("express");
//网络请求模块
var request = require("request");
//引入nodejs文件系统模块
const fs = require('fs');
//引入body-parser
//包含在请求正文中提交的键/值对数据。 
//默认情况下,它是未定义的,并在使用body-parser中间件时填充。
var bodyParser = require('body-parser');
var app = express();
//解析 application/x-www-form-urlencoded,limit:'20mb'用于设置请求的大小
//解决nodejs Error: request entity too large问题
app.use(bodyParser.urlencoded({ limit:'20mb',extended: true })); 
//设置跨域访问
app.all('*', function(req, res, next) {
  res.header("Access-Control-Allow-Origin", "*");
  res.header("Access-Control-Allow-Headers", "X-Requested-With");
  res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
  res.header("Content-Type", "application/json;charset=utf-8");
  next();
});
//上传图片
app.post('/upload',function(req,res){
  var imgData = req.body.url;
  var base64Data = imgData.replace(/^data:image\/\w+;base64,/, "");
  var dataBuffer = new Buffer(base64Data, 'base64');
  fs.writeFile("image.png", dataBuffer, function(err) {
    if(err){
      res.send(err);
    }else{
      res.send("保存成功!");
    }
  });
})

var server = app.listen(4444, function() {
  console.log('监听端口 4444');
});

angular2前台代码

//上传图片
 /*
 *   let data = {
 *    size: '125422',
 *    type: 'image/jpeg',
 *    name: 'test.jpg',
 *    url: base64
 *   };
 *获取图片的base64码可以通过FileReader获取
 */

 uploadImage(data) {
  return new Promise((resolve, reject) => {
   let headers = new Headers({
    'Content-Type': 'application/x-www-form-urlencoded'
   });
   let options = new RequestOptions({
    headers: headers
   });
   this.http.post("http://localhost:4444/upload", this.toQueryString(data),options)
    .map(res => res.json())
    .subscribe(data => { resolve(data), error => { reject(error) } })
  })
 }


// JSON参数序列化
  private toQueryString(obj) {
   let result = [];
   for (let key in obj) {
    key = encodeURIComponent(key);
    let values = obj[key];
    if (values && values.constructor == Array) {
     let queryValues = [];
     for (let i = 0, len = values.length, value; i < len; i++) {
      value = values[i];
      queryValues.push(this.toQueryPair(key, value));
     }
     result = result.concat(queryValues);
    } else {
     result.push(this.toQueryPair(key, values));
    }
  }
   return result.join('&');
  }
  private toQueryPair(key, value) {
   if (typeof value == 'undefined') {
    return key;
   }
   return key + '=' + encodeURIComponent(value === null ? '' : String(value));
  }

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

NodeJs 相关文章推荐
NodeJS学习笔记之(Url,QueryString,Path)模块
Jan 13 NodeJs
nodejs如何获取时间戳与时间差
Aug 03 NodeJs
详解nodejs 文本操作模块-fs模块(一)
Dec 22 NodeJs
nodejs个人博客开发第四步 数据模型
Apr 12 NodeJs
nodejs处理图片的中间件node-images详解
May 08 NodeJs
nodejs集成sqlite使用示例
Jun 05 NodeJs
nodejs socket服务端和客户端简单通信功能
Sep 14 NodeJs
NVM安装nodejs的方法实用步骤
Jan 16 NodeJs
Nodejs libuv运行原理详解
Aug 21 NodeJs
Nodejs + Websocket 指定发送及群聊的实现
Jan 09 NodeJs
NodeJS模块Buffer原理及使用方法解析
Nov 11 NodeJs
windows如何把已安装的nodejs高版本降级为低版本(图文教程)
Dec 14 NodeJs
深入nodejs中流(stream)的理解
Mar 27 #NodeJs
nodejs学习笔记之路由
Mar 27 #NodeJs
NodeJS处理Express中异步错误
Mar 26 #NodeJs
简单好用的nodejs 爬虫框架分享
Mar 26 #NodeJs
nodejs开发——express路由与中间件
Mar 24 #NodeJs
详解NodeJS框架express的路径映射(路由)功能及控制
Mar 24 #NodeJs
NodeJS学习笔记之Module的简介
Mar 24 #NodeJs
You might like
星际实力自我测试
2020/03/04 星际争霸
PHP 身份证号验证函数
2009/05/07 PHP
PHP实现多条件查询实例代码
2010/07/17 PHP
PHP下利用header()函数设置浏览器缓存的代码
2010/09/01 PHP
php中全局变量global的使用演示代码
2011/05/18 PHP
php中的观察者模式简单实例
2015/01/20 PHP
PHP中把有符号整型转换为无符号整型方法
2015/05/27 PHP
PHP Opcache安装和配置方法介绍
2015/05/28 PHP
关于jQuery参考实例 1.0 jQuery的哲学
2013/04/07 Javascript
详解Vue2+Echarts实现多种图表数据可视化Dashboard(附源码)
2017/03/21 Javascript
第一次记录Bootstrap table学习笔记(1)
2017/05/18 Javascript
解决bootstrap中使用modal加载kindeditor时弹出层文本框不能输入的问题
2017/06/05 Javascript
JavaScript实现无刷新上传预览图片功能
2017/08/02 Javascript
webpack之引入图片的实现及问题
2018/10/08 Javascript
javascript实现前端成语点击验证
2020/06/24 Javascript
在Vue 中实现循环渲染多个相同echarts图表
2020/07/20 Javascript
[52:15]2014 DOTA2国际邀请赛中国区预选赛5.21 HGT VS LGD-GAMING
2014/05/23 DOTA
Python图片转换成矩阵,矩阵数据转换成图片的实例
2018/07/02 Python
Anaconda2 5.2.0安装使用图文教程
2018/09/19 Python
GitHub 热门:Python 算法大全,Star 超过 2 万
2019/04/29 Python
Django获取应用下的所有models的例子
2019/08/30 Python
浅谈Django2.0 加xadmin踩的坑
2019/11/15 Python
PyQt5 界面显示无响应的实现
2020/03/26 Python
Python使用socket_TCP实现小文件下载功能
2020/10/09 Python
使用placeholder属性设置input文本框的提示信息
2020/02/19 HTML / CSS
值传递还是引用传递
2015/02/08 面试题
迟到检讨书5000字
2014/01/31 职场文书
校园广播稿500字
2014/02/04 职场文书
《学棋》教后反思
2014/04/14 职场文书
怀念母亲教学反思
2014/04/28 职场文书
论文答谢词
2015/01/20 职场文书
颐和园英文导游词
2015/01/30 职场文书
交通事故案件代理词
2015/05/23 职场文书
mysql 8.0.24版本安装配置方法图文教程
2021/05/12 MySQL
react中的DOM操作实现
2021/06/30 Javascript
yyds什么意思?90后已经听不懂00后讲话了……
2022/02/03 杂记