位置: 编程技术 - 正文

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

  • 企业所得税申报表
  • 差旅费计入工资成本吗
  • 小规模零申报增值税
  • 应交税费科目核算
  • 固定资产累计折旧借贷方向
  • 核定增收和查账增收的区别
  • 企业所得税政策最新2023税率
  • 社保滞纳金是否影响企业信用等级
  • 车辆租赁费用标准
  • 增值税计提金额
  • 一般纳税人收到普票如何入账
  • 普通发票年份代码有什么具体含义?
  • 国有划拨地是否能转让土地
  • 增资后工商怎么变更
  • 按月预缴企业所得税的企业有哪些
  • 海关增值税当月可以抵扣吗
  • 季度预缴所得税可以弥补以前亏损吗
  • 老板垫付的货款怎么做凭证?
  • safari浏览器开发者模式
  • 事业单位负债类科目包括哪些科目
  • 职工福利费的会计科目是什么
  • 无形资产摊销是什么科目
  • 网络平台上进行网络营销
  • 咋激活windows
  • 收到押金缴国库费怎么办
  • 股权转让要交什么税举例
  • 会计分录编制的步骤
  • 记载资金的账簿印花税的税率是多少
  • 结转本年利润的分录怎么写
  • thinkphp框架结构
  • php背景图片代码
  • vite2.0 vue
  • 可予税前扣除的合理部分
  • 债权转让收益需缴税吗
  • phpcms怎么用
  • python中exec执行如何获取返回值
  • 小规模纳税人销售商品会计分录
  • sql中判断函数
  • 茶叶企业所得税减免
  • 免税企业税金及附加计算
  • mysql数据库压力测试工具
  • 账务处理程序的定义
  • 免税收入不征税收入计入收入总额吗
  • 其他收益和其他综合收益属于什么科目
  • 缴纳印花税如何写分录
  • 跨年度未开发票第二年如何做确认收入?
  • 公司基本账户有银行卡吗
  • 应交增值税一转出未交增值税
  • 人力资源差额税率
  • 财务报表中的存货包括哪些内容
  • 以前年度应收账款少记怎么处理
  • 主营业务成本怎么结转本年利润
  • 留存收益属于什么会计要素
  • sql根据逗号分割数据
  • 数据库中的内容怎么换行
  • CentOS 6.5 i386 安装MySQL 5.7.18详细教程
  • window10自带的软件有哪些
  • services.exe是什么文件
  • windows8.1关机
  • 苹果完美越狱最新消息
  • win7玩dnf总是未响应
  • win7窗口大小怎么设置
  • win10无法回退到以前的版本怎么办
  • linux升级系统版本
  • win8补丁官网
  • Win10 Mobile RedStone预览版14267已知问题与修复内容汇总
  • opengl裁剪平面
  • dos批处理命令大全
  • jquery时间格式
  • 批处理 输出换行
  • 字符串截取用什么方法
  • if条件程序
  • Unity 管理www类访问的写法
  • jquery控制台输出
  • android(8) ViewPager页面滑动切换
  • js函数详解
  • 专票开出去了多长时间必须打入账户
  • 国税申报密码忘了怎么办
  • 土地增值税分期清算条件?
  • 美国网购消费者个人信息保护法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设