angular2+nodejs實(shí)現(xiàn)圖片上傳功能
更新時(shí)間:2017年03月27日 15:55:57 作者:花開花又謝
這篇文章主要介紹了angular2+nodejs實(shí)現(xiàn)圖片上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
在使用angular2進(jìn)行圖片上傳的時(shí)候,遇到了各種各樣的問題。在多番嘗試之后最終成功上傳圖片,下面將我的方法分享給大家:
nodejs 后臺(tái)代碼
var express = require("express");
//網(wǎng)絡(luò)請(qǐng)求模塊
var request = require("request");
//引入nodejs文件系統(tǒng)模塊
const fs = require('fs');
//引入body-parser
//包含在請(qǐng)求正文中提交的鍵/值對(duì)數(shù)據(jù)。
//默認(rèn)情況下,它是未定義的,并在使用body-parser中間件時(shí)填充。
var bodyParser = require('body-parser');
var app = express();
//解析 application/x-www-form-urlencoded,limit:'20mb'用于設(shè)置請(qǐng)求的大小
//解決nodejs Error: request entity too large問題
app.use(bodyParser.urlencoded({ limit:'20mb',extended: true }));
//設(shè)置跨域訪問
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('監(jiān)聽端口 4444');
});
angular2前臺(tái)代碼
//上傳圖片
/*
* 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參數(shù)序列化
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));
}
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- angularjs客戶端實(shí)現(xiàn)壓縮圖片文件并上傳實(shí)例
- 通過AngularJS實(shí)現(xiàn)圖片上傳及縮略圖展示示例
- Angular下H5上傳圖片的方法(可多張上傳)
- AngularJs上傳前預(yù)覽圖片的實(shí)例代碼
- angularjs實(shí)現(xiàn)多張圖片上傳并預(yù)覽功能
- angularjs點(diǎn)擊圖片放大實(shí)現(xiàn)上傳圖片預(yù)覽
- Angularjs上傳圖片實(shí)例詳解
- Angularjs實(shí)現(xiàn)上傳圖片預(yù)覽功能
- AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法分析
- Angular4實(shí)現(xiàn)圖片上傳預(yù)覽路徑不安全的問題解決
相關(guān)文章
關(guān)于Angularjs中自定義指令一些有價(jià)值的細(xì)節(jié)和技巧小結(jié)
這篇文章主要介紹了關(guān)于Angularjs中自定義指令一些有價(jià)值的細(xì)節(jié)和技巧小結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-04
@angular前端項(xiàng)目代碼優(yōu)化之構(gòu)建Api Tree的方法
這篇文章主要介紹了@angular前端項(xiàng)目代碼優(yōu)化之構(gòu)建Api Tree的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12
AngularJS基礎(chǔ) ng-hide 指令用法及示例代碼
本文主要介紹AngularJS ng-hide 指令,這里整理了ng-hide指令的基礎(chǔ)資料,并附實(shí)例代碼,有興趣的小伙伴參考下2016-08-08
詳解AngularJs中$sce與$sceDelegate上下文轉(zhuǎn)義服務(wù)
這篇文章給大家詳細(xì)介紹了AngularJs提供的嚴(yán)格上下文轉(zhuǎn)義服務(wù)$sce與$sceDelegate,文中介紹的很詳細(xì),有需要的朋友們可以參考借鑒。2016-09-09

