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.但这个中间件有缺 ...
随机推荐
- 【FAQ】关于华为地图服务定位存在偏差的原因及解决办法
一. 问题描述: 华为地图服务"我的位置"能力,在中国大陆地区,向用户展示他们在地图上的当前位置与用户的实际位置存在较大的偏差. 具体差别可以查看下方的图片: 二. 偏差较大的原因 ...
- ubuntu 基本指令
系统相关 df: disk free 用以显示系统上文件系统磁盘的使用情况 # 以M/G单位显示硬盘空间大小 df -h apt: advanced packaging tool 包管理工具 apt ...
- pinpoint部署
pinpoint是一个分析大型分布式系统的平台,提供解决方案来处理海量跟踪数据,主要面向基于tomcat的Java 应用. pinpoint使用HBASE储存数据. 下面介绍pinpoint部署及应用 ...
- spring源码解析(一) 环境搭建(各种坑的解决办法)
上次搭建spring源码的环境还是两年前,依稀记得那时候也是一顿折腾,奈何当时没有记录,导致两年后的今天把坑重踩了一遍,还遇到了新的坑,真是欲哭无泪;为了以后类似的事情不再发生,这次写下这篇博文来必坑 ...
- springboot的全局异常处理类
import lombok.extern.slf4j.Slf4j; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import or ...
- 【题解】CF631B Print Check
题面传送门 解决思路: 首先考虑到,一个点最终的情况只有三种可能:不被染色,被行染色,被列染色. 若一个点同时被行.列染色多次,显示出的是最后一次被染色的结果.所以我们可以使用结构体,对每一行.每一列 ...
- 删除redis对应key的缓存
[root@zhyly-pre-002 ~]# /usr/local/redis/bin/redis-cli -p 6379 #登录redis 127.0.0.1:6379> auth 'Red ...
- Selenium4+Python3系列(七) - Iframe、Select控件、交互式弹出框、执行JS、Cookie操作
前言 突然,想把所有之前未更新的常用Api操作.演示写出来,算是对API的一种完结吧. 下面按照Api模块来做逐一介绍. 一.iframe操作 iframe识别: 语法: driver.switch_ ...
- 【云原生 · Kubernetes】配置 Rancher docker 云平台
个人名片: 因为云计算成为了监控工程师 个人博客:念舒_C.ying CSDN主页️:念舒_C.ying 1.1 Rancher 概述 Rancher 是一个开源的企业级容器管理平台.通过 Ranc ...
- vs2019中使用Git,新建项目时总提示部分项目位于解决方案文件夹外
最终还是用Git工具传上去的. 小伙子,用Git Bush或者Git CMD 和Git GUI传吧 我是用Git GUI. Git GUI汉化.感谢大佬 https://blog.csdn.net/u ...