node.js接收前端上传的文件并保存到其他位置+后端代码支持进度条
一:直接上传文件,放入body里
1.前端代码
<input type="file" onchange="sendFiles(this.files)">
<script>
function sendFiles(files) {
const reader = new FileReader();
const file = files[0];
reader.readAsArrayBuffer(file);
reader.onload = function (e) {
fetch("http://127.0.0.1:3000/" + file.name, {
method: 'post',
body: e.target.result
});
};
}
</script>
2.后端nodejs接受文件并保存
const http = require('http');
const fs = require('fs');
// 这个文件可以 把资料存放到file文件夹下
http.createServer(function (request, response) {
response.setHeader('Access-Control-Allow-Origin', '*');
// 下面的这个意思是放到这个路径下,避免放到根目录
console.log(request.body)
request.pipe(fs.createWriteStream('./file' + request.url, {
// encoding:'binary' // 行
// encoding:'base64' // 行
encoding:'utf8' // 不知道为什么,这里怎么设置都不影响,
}));
response.end(`${request.url} done!`);
}).listen(3000);
二:上传文件支持utf-8以及另存到file文件夹里+带进度条
1.前端代码
// 前端 upload.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>上传文件demo</title>
<style media="screen">
.progress{
width: 50%;
height: 5px;
border: 1px solid #ccc;
border-radius: 4px;
margin-top: 10px;
position: relative;
}
.progress>span{
display: inline-block;
position: absolute;
border-radius: 4px;
top: 0;
left: 0;
height: 100%;
width: 0;
background-color: rgb(98, 230, 74);
transition: width 0.3s ease-out;
}
</style>
</head>
<body>
<input id="file" type="file" multiple>
<div class="progress">
<span></span>
</div>
<script type="text/javascript">
var http = function (option) {
// 过滤请求成功后的响应对象
function getBody (xhr) {
var text = xhr.responseText || xhr.response
if (!text) {
return text
}
try {
return JSON.parse(text)
} catch (err) {
return text
}
}
var xhr = new XMLHttpRequest();
// 自定义 beforeSend 函数
if(option.beforeSend instanceof Function) {
if (option.beforeSend(xhr) === false) {
return false
}
}
xhr.onreadystatechange = function () {
if (xhr.status === 200) {
if (xhr.readyState === 4) {
// 成功回调
option.onSuccess(getBody(xhr))
}
}
}
// 请求失败
xhr.onerror = function (err) {
option.onError(err)
}
xhr.open(option.type, option.url, true)
// 当请求为上传文件时回调上传进度
if (xhr.upload) {
xhr.upload.onprogress = function (event) {
if (event.total > 0) {
event.percent = event.loaded / event.total * 100;
}
// 监控上传进度回调
if (option.onProgress instanceof Function) {
option.onProgress(event)
}
}
}
// 自定义头部
const headers = option.headers || {}
for (var item in headers) {
xhr.setRequestHeader(item, headers[item])
}
xhr.send(option.data)
}
// 测试接口
http({
type: 'POST',
url: 'http://127.0.0.1:3000/test',
data: JSON.stringify({
name: 'yolo'
}),
onSuccess: function (data) {
console.log(data)
},
onError: function (err) {
console.log(err)
}
})
document.getElementById('file').onchange = function () {
var fileList = this.files, formData = new FormData();
Array.prototype.forEach.call(fileList, function (file) {
formData.append(file.name, file)
})
// 当上传的数据为 file 类型时,请求的格式类型自动会变为 multipart/form-data, 如果头部格式有特定需求,在我的 http 函数中传入 headers<Object> 即可,大家可自己查看,我这里没有什么特殊处理所以就不传了
http({
type: 'POST',
url: 'http://127.0.0.1:3000/upload',
data: formData,
onProgress: function (event) {
console.log(event.percent)
document.querySelector('.progress span').style.width = event.percent + '%';
},
onSuccess: function (data) {
console.log('上传成功')
},
onError: function (err) {
alert(err)
}
})
}
</script>
</body>
</html>
2.后端代码
// 上传文件支持utf-8以及另存到file文件夹里+带进度条
var express = require('express');
var path = require('path');
var fs = require('fs');
var app = express();
var bodyParser = require('body-parser'); // 过滤请求头部相应格式的body
var multer = require('multer');
var chalk = require('chalk'); // 只是一个 cli 界面字体颜色包而已
var log = console.log.bind(console);
const cors=require('cors');
//跨域请求cors
app.use(cors
(
{
// origin:"*" ,
// origin:"http://localhost:8080" ,
// origin:"http://10.22.12.12:4200" ,
origin:"http://127.0.0.1:5500" ,
credentials: true
}
)
);
app.use(express.static('static'));
// 接受 application/json 格式的过滤器
var jsonParser = bodyParser.json()
// 接受 application/x-www-form-urlencoded 格式的过滤器
var urlencodedParser = bodyParser.urlencoded({ extended: false })
// 接受 text/html 格式的过滤器
var textParser = bodyParser.text()
// 自定义 multer 的 diskStorage 的存储目录与文件名
var storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, 'file') // 注意一下这里,这个是设置上传到哪个文件夹的哦~~
},
filename: function (req, file, cb) {
cb(null, file.fieldname)
}
})
var upload = multer({ storage: storage })
// 页面渲染
app.get('/', function (req, res) {
res.sendFile(path.join(__dirname, 'view/upload.html'));
})
app.post('/test', textParser, jsonParser, function (req, res) {
log(req.body);
var httpInfo = http.address();
res.send({
host: httpInfo.address,
port: httpInfo.port
})
})
// 对应前端的上传接口 http://127.0.0.1:3000/upload, upload.any() 过滤时不对文件列表格式做任何特殊处理
app.post('/upload', upload.any(), function (req, res) {
log(req.files)
res.send({message: '上传成功'})
})
// 监控 web 服务
var http = app.listen(3000, '127.0.0.1', function () {
var httpInfo = http.address();
log(`创建服务${chalk.green(httpInfo.address)}:${chalk.yellow(httpInfo.port)}成功`)
})
参考文章:https://blog.csdn.net/yolo0927/article/details/78523020
node.js接收前端上传的文件并保存到其他位置+后端代码支持进度条的更多相关文章
- Nodejs学习笔记(八)--- Node.js + Express 实现上传文件功能(felixge/node-formidable)
目录 前言 formidable简介 创建项目并安装formidable 实现上传功能 运行结果 部分疑惑解析 写在之后 前言 前面讲了一个构建网站的示例,这次在此基础上再说说web的常规功能---- ...
- Nodejs学习笔记(八)—Node.js + Express 实现上传文件功能(felixge/node-formidable)
前言 前面讲了一个构建网站的示例,这次在此基础上再说说web的常规功能----文件上传,示例以一个上传图片的功能为例子 上传功能命名用formidable实现,示例很简单! PS:最近比较忙,距上一次 ...
- web api 如何通过接收文件流的方式,接收客户端及前端上传的文件
服务端接收文件流代码: public async Task<HttpResponseMessage> ReceiveFileByStream() { var stream = HttpCo ...
- 基于node.js的websocket上传小功能
一.node.js 在目录里新建index.js var ws = require("nodejs-websocket"); console.log("开始建立连接... ...
- Node.js实现图片上传功能
node接口实现 const express = require('express') const mysql = require('mysql') const cors = require('cor ...
- Node.js之图片上传
本文用node进行图片上传主要借助formidable插件,具体使用步骤如下: 1.安装formidable插件 npm install formidable -g 2.引入依赖包 const for ...
- js截取图片上传(仅原理)----闲的无聊了代码就不共享了!写的难看,不好意思给你们看了(囧)
就算世界再坑爹,总有一些属性能带你走出绝望(伟大的absolute) 今天吐槽一下!......在我的世界里没有正统UI,所以效果图永远都是那么坑爹! 这里我要感谢有个position:absolut ...
- Azure IoT Hub 十分钟入门系列 (4)- 实现从设备上传日志文件/图片到 Azure Storage
本文主要分享一个案例: 10分钟内通过Device SDK上传文件到IoTHub B站视频:https://www.bilibili.com/video/av90224073/ 本文主要有如下内容: ...
- python实现socket上传下载文件-进度条显示
在python的socket编程中,可以实现上传下载文件,并且在下载的时候,显示进度条,具体的流程如下图所示: 1. 服务器端代码如下: [root@python 519]# cat server.p ...
- node之post提交上传
post文件上传 multer 中间件 在node中 express为了性能考虑采用按需加载的方式,引入各种中间件来完成需求, 平时解析post上传数据时候,是用body-parse.但这个中间件有缺 ...
随机推荐
- 关于引用JS和CSS文件刷新浏览器缓存问题,部署服务器后客户端样式不刷新
问题描述 对样式的css文件进行了修改,部署到服务器后访问发现页面展示不正常,但是刷新之后就会展示正常. 问题分析 研究之后发现可能的原因有 css文件过大,加载缓慢 本地缓存问题,虽然服务器修改了c ...
- day03-CSS
CSS 1.css介绍 css指的是层叠样式表(cascading style sheets) 官方文档:https://www.w3school.com.cn/css/index.asp 为什么需要 ...
- Debian 参考手册之第6章Debian档案库
来源:https://www.debian.org/doc/manuals/debian-faq/ftparchives#oldcodenames 第 6 章 Debian 档案库 目录 6.1. 有 ...
- CentOS6/7 配置守护进程
CentOS6.x CentOS6中转用Upstrat代替以前的init.d/rcX.d的线性启动方式. 一.相关命令 通过initctl help可以查看相关命令 [root@localhost ~ ...
- 嵌入式-C语言基础:字符串strlen和sizeof的区别
strlen表示的实际的字符串长度,不会把字符串结束符'\0'计算进去,而sizeof则不是实际的字符串长度,它会把字符串的结束标识符'\0'也包含进去. #include<stdio.h> ...
- perl按照健值排序
perl中如何将按hash key值排序 BRUSH2 10752 11263 BUFFER 11264 11775 MEGASONIC 11776 12287 INPUTMODULE 12800 1 ...
- K8S节点配置资源驱逐
#参考文章:https://www.cnblogs.com/zhangrui153169/p/15726165.html 当节点内存到达多少时.对节点的pod进行驱逐 [root@lecode-tes ...
- 线性时间选择(含平均情况O(n)和最坏情况O(n)算法)
前言 本篇文章我将介绍 期望为线性时间 的选择算法和 最坏情况为线性时间 的选择算法,即分别为 平均情况下时间复杂度为O(n) 和 最坏情况下时间复杂度为O(n) 的线性时间选择.以下包含了我自己的全 ...
- ubuntu等debian系linux系统添加人脸识别howdy
准备 proxychains proxychains是用来给终端走代理的软件,因为下载howdy的时候有一部分的文件的服务器在国外,且被墙了. 安装proxychains sudo apt insta ...
- matplotlib详细教学
Matplotlib初相识 认识matplotlib Matplotlib是一个Python 2D绘图库,能够以多种硬拷贝格式和跨平台的交互式环境生成出版物质量的图形,用来绘制各种静态,动态,交互式的 ...