位置: 编程技术 - 正文

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 代码加密)

  • 明股实债的风险与防范
  • 财务制度怎么定
  • 毛利率在餐饮中表示什么意思?
  • 5个点的税率是多少
  • 售后回租业务是什么
  • 纳税人如何申请享受税收减免优惠
  • 产品售后维修产品介绍
  • 互联网企业资产负债表特征
  • 发票专用章在哪里盖章
  • 企业自查补税报告怎么写?
  • 税务局锁了开票系统票已领出还可以开出来吗
  • 预售 首付
  • 企业被列为风险纳税人税控开票会显示什么
  • 个人借款取得的利息收入要交税吗
  • 补提以前年度税费应该计入
  • 确认坏账损失的分录怎么做
  • 原料采购入库检测损耗的会计处理怎么做?
  • 企业成本费用包含
  • 一般纳税人增票流程
  • win11我的电脑不在桌面显示
  • 主营业务成本是借方增加还是贷方增加
  • 预收款交税未开发票申报表怎么
  • 认缴出资怎么记账
  • packethsvc.exe - packethsvc是什么进程 有什么用
  • 误餐费怎么入账
  • 移动临时文件
  • 股权折价转让
  • 电商第三方平台规则的特点
  • 应收账款怎么做分录
  • 企业注销时实收资本需要交税吗
  • win10任务栏隐藏正在运行的程序
  • 2017年8月21日是什么日子
  • 最贵的苹果4
  • 境外付款
  • php 正则函数
  • 商业汇票抵付前欠货款的分录
  • 国税局发票打印软件下载
  • php设置header参数
  • 【机器学习】python实现吴恩达机器学习作业合集(含数据集)
  • pyecharts 表格
  • 2021年车辆检测
  • 自动驾驶感知算法
  • 广告费和业务招待费扣除标准中的全年销售收入是指
  • 什么情况下专票税率为1
  • 待处理财产损益期末结转到哪里
  • 外贸企业应交税费计入
  • 营改增方案
  • 小规模纳税人免税政策2023年
  • 计划成本法存货会计分录
  • 职工薪酬纳税调整
  • 材料成本差异的含义
  • 固定资产不可以搬走,那什么资产能搬走的?
  • 交易费用计入何种科目
  • 预收账款怎么处理
  • 新公司的注册
  • 保险赔偿收入如何减税额
  • 出口免抵退和免退有什么区别
  • 免征企业所得税的有哪些行业
  • 一般纳税人进货的会计分录怎么做
  • 如何用win7
  • Windows Server 2008使用软件授权管理工具
  • 生产环境如何对linux进行合理分区
  • 电脑没有系统了如何重装系统
  • windows任务管理器调用的方法
  • ghost出现错误
  • 怎么配置命令
  • Win7系统如何开启移动到文件夹选项
  • paytime.exe - paytime是什么进程 有什么用
  • win10预览版好吗
  • cocos2dx怎么打开
  • jquery jsonview
  • linux同名文件
  • 半透明图层怎么制作
  • shell 1>&2 2>&1 &>filename重定向的含义和区别
  • html加载条代码
  • 程序员 master
  • 税务系统更新不能开发票
  • 企业个税申报系统密码忘记了在哪能找回呢?
  • 保险公司优惠的款项什么时候退款
  • 地税局与税务局的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设