angglar 2+nodejsは写真のアップロードを実現します.
3053 ワード
angglar 2を使って画像をアップロードする時、様々な問題に出会いました.いろいろな試みの末に写真をアップロードしました.私の方法を皆さんに共有します.
nodejsバックグラウンドコード
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');
});
アングラー2フロントコード //
/*
* 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));
}