在使用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));
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# angular2
# nodejs
# 图片上传
# angularjs客户端实现压缩图片文件并上传实例
# 通过AngularJS实现图片上传及缩略图展示示例
# Angular下H5上传图片的方法(可多张上传)
# AngularJs上传前预览图片的实例代码
# angularjs实现多张图片上传并预览功能
# angularjs点击图片放大实现上传图片预览
# Angularjs上传图片实例详解
# Angularjs实现上传图片预览功能
# AngularJS实现图片上传和预览功能的方法分析
# Angular4实现图片上传预览路径不安全的问题解决
# 上传图片
# 并在
# 它是
# 可以通过
# 给大家
# 文件系统
# 大家多多
# 各种各样
# 情况下
# 序列化
# Requested
# PUT
# true
# Methods
# res
# header
# function
# req
# Origin
相关文章:
专业公司网站制作公司,用什么语言做企业网站比较好?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
如何挑选最适合建站的高性能VPS主机?
,sp开头的版面叫什么?
建站主机CVM配置优化、SEO策略与性能提升指南
外贸公司网站制作,外贸网站建设一般有哪些步骤?
如何快速生成可下载的建站源码工具?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
如何在西部数码注册域名并快速搭建网站?
建站之星备案流程有哪些注意事项?
如何通过虚拟主机快速搭建个人网站?
建站主机SSH密钥生成步骤及常见问题解答?
网站制作软件有哪些,制图软件有哪些?
如何在云主机上快速搭建多站点网站?
如何高效搭建专业期货交易平台网站?
广德云建站网站建设方案与建站流程优化指南
如何正确选择百度移动适配建站域名?
网站图片在线制作软件,怎么在图片上做链接?
黑客入侵网站服务器的常见手法有哪些?
建站主机系统SEO优化与智能配置核心关键词操作指南
宝塔建站后网页无法访问如何解决?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解
北京营销型网站制作公司,可以用python做一个营销推广网站吗?
建站主机选择指南:服务器配置与SEO优化实战技巧
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
建站主机助手选型指南:2025年热门推荐与高效部署技巧
如何通过西部数码建站助手快速创建专业网站?
建站之星伪静态规则如何正确配置?
如何在搬瓦工VPS快速搭建网站?
如何选择最佳自助建站系统?快速指南解析优劣
建站之星后台管理如何实现高效配置?
存储型VPS适合搭建中小型网站吗?
建站之星如何一键生成手机站?
如何在服务器上配置二级域名建站?
如何在橙子建站上传落地页?操作指南详解
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何在万网开始建站?分步指南解析
成都网站制作公司哪家好,四川省职工服务网是做什么用?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
专业网站建设制作报价,网页设计制作要考什么证?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
微信推文制作网站有哪些,怎么做微信推文,急?
h5网站制作工具有哪些,h5页面制作工具有哪些?
建站之星3.0如何解决常见操作问题?
如何在IIS管理器中快速创建并配置网站?
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
如何破解联通资金短缺导致的基站建设难题?
*请认真填写需求信息,我们会在24小时内与您取得联系。