node端上传图片踩坑记录

简介: 最近在做一个项目,有需要在node端进行上传图片,一直搞得都是浏览器的上传,node端这次是头一次搞,踩了不少坑,前后花了好几个小时的时间。现在把一些遇到得一些问题和心得记录下来。

最近在做一个项目,有需要在node端进行上传图片,一直搞得都是浏览器的上传,node端这次是头一次搞,踩了不少坑,前后花了好几个小时的时间。现在把一些遇到得一些问题和心得记录下来。58962b0acf7a2b6e5aa230ce971128ec_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.jpg

node能用formdata吗?



实现这个功能首先会想到node端用什么来封装上传的数据,后来确定了是可以用formdata的,需要安装一个npm包就可以。

而且官方也给了一些参考的代码,【坑就在这里】。


然后发起http请求我这里用的是node-fetch,其实还有其他的包都是可以用的,这个看自己喜好。


当我拿过来官方的代码配合node-fetch调试的时候,发现图片的内容始终是无法发送过去,官方参考代码如下:


09cb0ccd27853808e3eaf6c7bca4cc02_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.jpg


是不是很简单,特别简单。

开始我在想这个代码 fs.createReadStream('/foo/bar.jpg')


肯定是formdata内部给处理了,拿到了图片的数据。


尝试了多种方式拿到图片的数据,也在网上找了很多方法,但是都不对。


后来我就放弃了。。。。


回家的路上研究了下图片上传的原理,也就是formdata的原理,其实这个就是http协议的部分,数据已字节流的形式发送。


我们应该做的就是把图片的内容转成字节流就可以了,又看了下字节流,怎么转。网上找了很多资料,代码也有,拿过来就是错误的。


后来自己还是给写出来了,通过手动把图片的内容读取出来,然后转成字节流就可以了。


具体代码贴上:

fs.readFile('tempimg/content-47713122-0.png', function (err, data) {
    if (err) {
        // 错误处理
        return;
    }
   //data 本身就是字节流了,所以不需要做任何转换
    fs.writeFileSync('copy.jpg', data); // 字节流保存为图片,测试看图片能否打开
    let form = new formData();
    form.append('pic', data);
    console.log(form);
    fetch('http://upload.test.com/upload.php', {
        body: form,
        method: 'POST',
        headers: form.getHeaders()
    }).then(res => {
        return res.json();
    }).then(data => {
        console.log(data);
    })
});


这个代码绝对可以运行。当前需要引入fs模块,安装fromdata模块。


总结


问题不能快速的解决,是因为不懂原理,而且长时间么有结果,会让自己脑子变的混乱,这个时候就应该歇歇了,做点别的。为什么我网查的代码都是错误的,看着对,运行就错,是我人品有问题吗?


本次只是解决了问题,但是背后的机制并没有完全搞明白,还是要继续学习啊。时间紧迫,就写到这里,希望可以引起共鸣。

目录
相关文章
|
JavaScript 对象存储
阿里云 OSS 如何通过 Node.js 上传图片 #49
阿里云 OSS 如何通过 Node.js 上传图片 #49
448 0
|
存储 中间件 数据库
【Node.js+koa--后端管理系统】上传图片 、动态配图 | 处理图片大小
【Node.js+koa--后端管理系统】上传图片 、动态配图 | 处理图片大小
315 0
【Node.js+koa--后端管理系统】上传图片 、动态配图 | 处理图片大小
|
JavaScript 前端开发 API
node+express上传图片到七牛
本人微信公众号:前端修炼之路,欢迎关注 最近做项目的时候有一个上传图片的需求,由于没有后端的配合,所以决定自己来搭个服务器,实现上传图片功能。
2696 0
|
4月前
|
JavaScript Unix Linux
nvm与node.js的安装指南
通过以上步骤,你可以在各种操作系统上成功安装NVM和Node.js,从而在不同的项目中灵活切换Node.js版本。这种灵活性对于管理不同项目的环境依赖而言是非常重要的。
1078 11
|
9月前
|
弹性计算 JavaScript 前端开发
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
Node.js 是一种高效的 JavaScript 运行环境,基于 Chrome V8 引擎,支持在服务器端运行 JavaScript 代码。本文介绍如何在阿里云上一键部署 Node.js 环境,无需繁琐配置,轻松上手。前提条件包括 ECS 实例运行中且操作系统为 CentOS、Ubuntu 等。功能特点为一键安装和稳定性好,支持常用 LTS 版本。安装步骤简单:登录阿里云控制台,选择扩展程序管理页面,安装 Node.js 扩展,选择实例和版本,等待创建完成并验证安装成功。通过阿里云的公共扩展,初学者和经验丰富的开发者都能快速进入开发状态,开启高效开发之旅。
|
8月前
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
7448 23
|
9月前
|
JavaScript 前端开发 数据可视化
【01】Cocos游戏开发引擎从0开发一款游戏-cocos环境搭建以及配置-Cocos Creator软件系统下载安装-node环境-优雅草卓伊凡
【01】Cocos游戏开发引擎从0开发一款游戏-cocos环境搭建以及配置-Cocos Creator软件系统下载安装-node环境-优雅草卓伊凡
545 2
【01】Cocos游戏开发引擎从0开发一款游戏-cocos环境搭建以及配置-Cocos Creator软件系统下载安装-node环境-优雅草卓伊凡
|
9月前
|
弹性计算 JavaScript 前端开发
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
|
存储 JavaScript 搜索推荐
Node框架的安装和配置方法
安装 Node 框架是进行 Node 开发的第一步,通过正确的安装和配置,可以为后续的开发工作提供良好的基础。在安装过程中,需要仔细阅读相关文档和提示,遇到问题及时解决,以确保安装顺利完成。
653 58
|
8月前
|
数据库
【YashanDB知识库】安装共享集群时报错:YAS-05721 invalid input parameter, reason: node name invalid
【YashanDB知识库】安装共享集群时报错:YAS-05721 invalid input parameter, reason: node name invalid
下一篇
oss云网关配置