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中的非阻塞方法介绍
Jun 05 NodeJs
利用NodeJS和PhantomJS抓取网站页面信息以及网站截图
Nov 18 NodeJs
跟我学Nodejs(三)--- Node.js模块
May 25 NodeJs
初始Nodejs
Nov 08 NodeJs
Nodejs学习item【入门手上】
May 05 NodeJs
详解Nodejs基于mongoose模块的增删改查的操作
Dec 21 NodeJs
nodejs入门教程六:express模块用法示例
Apr 24 NodeJs
nodejs后台集成ueditor富文本编辑器的实例
Jul 11 NodeJs
nodejs结合Socket.IO实现的即时通讯功能详解
Jan 12 NodeJs
nodejs require js文件入口,在package.json中指定默认入口main方法
Oct 10 NodeJs
nodejs异步编程基础之回调函数用法分析
Dec 26 NodeJs
nodejs开发一个最简单的web服务器实例讲解
Jan 02 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
php分页示例分享
2014/04/30 PHP
PHP静态成员变量
2017/02/14 PHP
js Dialog 去掉右上角的X关闭功能
2014/04/23 Javascript
AngularJS学习笔记之TodoMVC的分析
2015/02/22 Javascript
jQuery()方法的第二个参数详解
2015/04/29 Javascript
JavaScript中的toLocaleLowerCase()方法使用详解
2015/06/06 Javascript
jQuery获取页面元素绝对与相对位置的方法
2015/06/10 Javascript
JS实现跟随鼠标的链接文字提示框效果
2015/08/06 Javascript
js选项卡的制作方法
2017/01/23 Javascript
JavaScript与JQUERY获取元素的宽、高和位置
2017/02/26 Javascript
Bootstrap4如何定制自己的颜色和风格
2018/02/26 Javascript
jQuery实现输入框的放大和缩小功能示例
2018/07/21 jQuery
Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖
2018/11/25 Javascript
mpvue微信小程序多列选择器用法之省份城市选择的实现
2019/03/07 Javascript
Node.js + express基本用法教程
2019/03/14 Javascript
KnockoutJS数组比较算法实例详解
2019/11/25 Javascript
Python使用MySQLdb for Python操作数据库教程
2014/10/11 Python
AI人工智能 Python实现人机对话
2017/11/13 Python
基于python进行桶排序与基数排序的总结
2018/05/29 Python
python中的变量如何开辟内存
2018/06/26 Python
python3实现钉钉消息推送的方法示例
2019/03/14 Python
Python2.7版os.path.isdir中文路径返回false的解决方法
2019/06/21 Python
numpy.array 操作使用简单总结
2019/11/08 Python
python飞机大战pygame游戏背景设计详解
2019/12/17 Python
Python 使用 prettytable 库打印表格美化输出功能
2019/12/26 Python
Django框架配置mysql数据库实现过程
2020/04/22 Python
如何让PyQt5中QWebEngineView与JavaScript交互
2020/10/21 Python
元旦文艺汇演主持词
2014/03/26 职场文书
《永远的白衣战士》教学反思
2014/04/25 职场文书
离职保密承诺书
2014/05/28 职场文书
防汛工作情况汇报
2014/10/28 职场文书
2014年办公室文秘工作总结
2014/12/09 职场文书
干部个人考察材料
2014/12/24 职场文书
2015年董事长秘书工作总结
2015/07/23 职场文书
golang 实现时间戳和时间的转化
2021/05/07 Golang
python利用while求100内的整数和方式
2021/11/07 Python