位置: 编程技术 - 正文

Node.js实现文件上传(nodejs实现文件压缩下载)

编辑:rootadmin

推荐整理分享Node.js实现文件上传(nodejs实现文件压缩下载),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs实现文件上传到云服务器,nodejs实现文件上传到云服务器,node.js写文件,nodejs实现文件上传次数限制,nodejs实现文件上传次数限制,nodejs实现文件压缩下载,nodejs实现文件下载,nodejs实现文件上传,内容如对您有帮助,希望把文章链接给更多的朋友!

在工作中碰到了这样的需求,需要用nodejs 来上传文件,之前也只是知道怎么通过浏览器来上传文件, 用nodejs的话, 相当于模拟浏览器的行为。 google 了一番之后, 明白了浏览器无非就是利用http协议来给服务器传输数据, 具体协议就是《RFC - Form-based File Upload in HTML》, 在浏览器上通过form 表单来上传文件就是通过这个协议,我们可以先看看浏览器给服务端发送了什么数据, 就可以依葫芦画瓢的把上传功能实现出来。说起form 表单上传文件的话, 大家应该很熟悉:

提交时, 用fiddler 抓包可以看到向服务端发出这样的数据:

POST HTTP/1.1Host: www.qq.comContent-Length: Content-Type: application/x-www-form-urlencoded; charset=UTF-8

text1=hello&text2=world

值得注意的是Content-Type默认为application/x-www-form-urlencoded,所以消息会经过URL编码。比如“你好”会编码为 %E4%BD%A0%E5%A5%BD。

接下来我们看一下通过form 表单是怎么上传的。大家应该也不陌生:

然后新建一个只有hello world字样的upload.txt文本文件上传上去,我们再吃用fiddler 来抓下包, 可以发现发送过去的数据稍微复杂了一些(已经去掉了很多的其它没关系的请求行,比如缓存控制和cookie之类的):

POST HTTP/1.1Host: www.qq.comContent-Length: Content-Type: multipart/form-data; boundary=----WebKitFormBoundarywr3X7sXBYQQ4ZF5G

Node.js实现文件上传(nodejs实现文件压缩下载)

------WebKitFormBoundarywr3X7sXBYQQ4ZF5GContent-Disposition: form-data; name="myfile"; filename="upload.txt"Content-Type: text/plain

hello world

------WebKitFormBoundarywr3X7sXBYQQ4ZF5G--

根据RFC 的定义,我们需要生成一段边界数据,这个数据不能在内容的其它地方出现,这个可以自己定义, 在每个浏览器的生成算法可能都不一样, 上面的boundary就是分隔数据,生成了分隔数据之后, 就可以把分隔数据放在头部的Content-Type里面传送给服务端, 也就是上文的 Content-Type: multipart/form-data; boundary=----WebKitFormBoundarywr3X7sXBYQQ4ZF5G, 另外,上传的内容,需要用分隔数据来分隔成若干个段,然后每段数据里面都有文件的文件名,还有上传时候的name,服务端就是用这个name来接收文件,还有文件的类型Content-Type,在这个例子里是 text/plain,如果上传的是png图片就是image/png。文件类型的一个空行后就是所上传的文件的内容,在这个例子里也是为了容易理解所以上传的是文本文件所以内容直接就能够显示出来,如果上传的是图片文件, 因为是二进制文件,fiddler 就显示的是乱码。 文件的内容结束之后就是一个空行再加上边界数据。

了解了发送格式的细节之后, 下一步就是使用nodejs来编程实现,简单来讲, 就是按照格式把数据发送给服务端就行了。

本文重点在于了解协议并且用代码实现出来, 代码组织上面还有很多优化的地方。

最后在本地apache,简单写一个php来保存上传的文件来用作测试:

另外,根据RFC 还可以实现一次上传多个文件的功能, 这个在这里就不详述, 需要的话可以详细参考RFC 来实现。

以上所述是小编给大家介绍的Node.js实现文件上传,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

深入解析桶排序算法及Node.js上JavaScript的代码实现 1.桶排序介绍桶排序(Bucketsort)是一种基于计数的排序算法,工作的原理是将数据分到有限数量的桶子里,然后每个桶再分别排序(有可能再使用别的排序

Node.js DES加密的简单实现 常见的加密算法基本分为这几类,1:线性散列算法、2:对称性加密算法、3、非对称性加密算法(记记记)线性散列算法(签名算法):MD5,SHA1,HMAC比如MD5

nodejs加密Crypto的实例代码 加密技术通常分为两大类:对称式和非对称式。对称式加密:就是加密和解密使用同一个密钥,通常称之为SessionKey这种加密技术在当今被广泛采用,如

标签: nodejs实现文件压缩下载

本文链接地址:https://www.jiuchutong.com/biancheng/370754.html 转载请保留说明!

上一篇:Nodejs中 npm常用命令详解(nodejs nodemon)

下一篇:Node.js DES加密的简单实现(nodejs 代码加密)

  • 境外企业在中国境内承包建筑工程应在
  • 收购农副产品怎么做账
  • 新入职员工哪月交社保
  • 债券到期收益率计算器
  • 所得税申报表填写样本
  • 劳务派遣差额计税公式
  • 高新技术企业费用认定
  • 本月完工入库会计分录
  • 事业单位开办费账务处理
  • 佣金增值税
  • 收到投资款需要什么原始凭证
  • 土地使用税如何计算缴纳
  • 投资款的印花税的纳税义务时间
  • 7月财务报表行次三大变化
  • 股权变更之后税务变更
  • 多缴税款如何办理退税
  • 专票的六位开票代码指的是什么
  • 原本可以打开的软件
  • 实收资本账户的核算内容是什么
  • 企业购买银行理财
  • 出口货物免抵退税 组织收入 影响
  • 出租不动产增值税纳税义务发生时间
  • 提前支付的费用记账
  • 多开票金额会计分录
  • 生产企业出口货物增值税如何申报
  • 对于个体工商户不需要满足累计经营三个月以上的条件
  • allegro器件移动不了
  • idea如何运行springboot项目
  • php读取xml文件
  • 预收账款和应收账款的账务处理
  • 以前年度损益调整账务处理分录
  • 出售土地账务如何处理
  • 多模态 融合
  • centos7搭建http
  • jquery+thinkphp实现跨域抓取数据的方法
  • 资产减值损失为什么要调增
  • 其他权益工具是什么会计科目
  • 母公司和子公司可以一起投标吗
  • 织梦如何添加浮动广告
  • SQLite教程(十二):锁和并发控制详解
  • 税控盘每年要交年费吗
  • 工程咨询服务发展的指导意见有哪些
  • 个人所得税汇算清缴
  • 小企业长期债券投资交易费用
  • 企业报税流程是什么样的
  • 土地出让金抵减增值税申报怎么填
  • 出口货物备案单证目录怎么填
  • 存在弃置费用的固定资产有哪些
  • 月底库存现金可以有余额吗
  • 车间消耗品的会计分录
  • 赠送礼品怎么入账
  • 分公司往子公司投资如何做税务处理?
  • 民办非企业单位什么意思
  • 哪几种情况涉及到进项税额的转出
  • 购置成本由什么构成
  • 电子承兑汇票到期网银上怎么操作
  • Ubuntu下MySQL安装及配置远程登录教程
  • windows xp 注册表故障恢复
  • win7打开注册表的命令
  • ssh免密登录执行shell
  • kcleaner是什么文件夹
  • mac book air安装
  • win7 安装系统
  • win8系统如何恢复出厂设置
  • android自定义搜索框
  • Extjs Ext.MessageBox.confirm 确认对话框详解
  • windows更新
  • 谈谈关于中华文明的五个突出特性
  • shell 记录日志
  • 资源加载中是什么原因
  • android sdkmanager
  • jquery中的$是什么
  • jquery 导航
  • python dj
  • js性能优化方法
  • javascript闭包运行原理
  • 公司的完税证明必须打印吗
  • 差额征税可以全部抵成本么?
  • 怎样在江苏智慧人社上停保
  • 河北省国家税务局电子税务局官网入口
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设