最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

angular2和nodejs实现图片上传的的的功能

来源:动视网 责编:小采 时间:2020-11-27 19:34:45
文档

angular2和nodejs实现图片上传的的的功能

angular2和nodejs实现图片上传的的的功能:这篇文章主要介绍了angular2+nodejs实现图片上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下在使用angular2进行图片上传的时候,遇到了各种各样的问题。在多番尝试之后最终成功上传图片,下面将我的方法分享给大家:nodejs 后台代码var
推荐度:
导读angular2和nodejs实现图片上传的的的功能:这篇文章主要介绍了angular2+nodejs实现图片上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下在使用angular2进行图片上传的时候,遇到了各种各样的问题。在多番尝试之后最终成功上传图片,下面将我的方法分享给大家:nodejs 后台代码var


这篇文章主要介绍了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实现图片上传的的的功能

angular2和nodejs实现图片上传的的的功能:这篇文章主要介绍了angular2+nodejs实现图片上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下在使用angular2进行图片上传的时候,遇到了各种各样的问题。在多番尝试之后最终成功上传图片,下面将我的方法分享给大家:nodejs 后台代码var
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top