91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

angular2+nodejs如何實現圖片上傳功能

發布時間:2021-06-21 12:43:36 來源:億速云 閱讀:187 作者:小新 欄目:web開發

這篇文章主要介紹angular2+nodejs如何實現圖片上傳功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

在使用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如何實現圖片上傳功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永善县| 长岭县| 毕节市| 潢川县| 凤台县| 宝鸡市| 丹寨县| 金堂县| 申扎县| 崇礼县| 林西县| 岐山县| 樟树市| 饶河县| 崇左市| 安阳市| 武威市| 个旧市| 石河子市| 天镇县| 宜春市| 中牟县| 百色市| 威宁| 顺昌县| 自贡市| 汨罗市| 秭归县| 苍山县| 安图县| 金塔县| 竹溪县| 景谷| 岫岩| 滨州市| 白朗县| 莆田市| 凯里市| 体育| 包头市| 东山县|