1. 博客搬家了,欢迎大家关注,https://bobjin.com

Node.js写文件的三种方式:

1、通过管道流写文件

  采用管道传输二进制流,可以实现自动管理流,可写流不必当心可读流流的过快而崩溃,适合大小文件传输(推荐)

  1. var readStream = fs.createReadStream(decodeURIComponent(root + filepath.pathname)); // 必须解码url
  2. readStream.pipe(res); // 管道传输
  3. res.writeHead(200,{
  4. 'Content-Type' : contType
  5. });
  6.  
  7. // 出错处理
  8. readStream.on('error', function() {
  9. res.writeHead(404,'can not find this page',{
  10. 'Content-Type' : 'text/html'
  11. });
  12. readStream.pause();
  13. res.end('404 can not find this page');
  14. console.log('error in writing or reading ');
  15. });

2、手动管理流写入

  手动管理流,适合大小文件的处理

  1. var readStream = fs.createReadStream(decodeURIComponent(root + filepath.pathname));
  2. res.writeHead(200,{
  3. 'Content-Type' : contType
  4. });
  5.  
  6. // 当有数据可读时,触发该函数,chunk为所读取到的块
  7. readStream.on('data',function(chunk) {
  8. res.write(chunk);
  9. });
  10.  
  11. // 出错时的处理
  12. readStream.on('error', function() {
  13. res.writeHead(404,'can not find this page',{
  14. 'Content-Type' : 'text/html'
  15. });
  16. readStream.pause();
  17. res.end('404 can not find this page');
  18. console.log('error in writing or reading ');
  19. });
  20.  
  21. // 数据读取完毕
  22. readStream.on('end',function() {
  23. res.end();
  24. });

3、通过一次性读完数据写入

  一次性读取完文件所有内容,适合小文件(不推荐)

  1.  
  1. fs.readFile(decodeURIComponent(root + filepath.pathname), function(err, data) {
  2. if(err) {
  3. res.writeHead(404,'can not find this page',{
  4. 'Content-Type' : 'text/html'
  5. });
  6. res.write('404 can not find this page');
  7.  
  8. }else {
  9. res.writeHead(200,{
  10. 'Content-Type' : contType
  11. });
  12. res.write(data);
  13. }
  14. res.end();
  15. });
  1. 博客搬家了,欢迎大家关注,https://bobjin.com
  1.  

Node.js写文件的三种方法的更多相关文章

  1. 前端js,css文件合并三种方式,bat命令

    前端js,css文件合并三种方式,bat命令 前端js文件该如何合并三个方式如下:1. 一个大文件,所有js合并成一个大文件,所有页面都引用它.2. 各个页面大文件,各自页面合并生成自己所需js的大文 ...

  2. JAVA写JSON的三种方法,java对象转json数据

    JAVA写JSON的三种方法,java对象转json数据 转自:http://www.xdx97.com/#/single?bid=5afe2ff9-8cd1-67cf-e7bc-437b74c07a ...

  3. VC中加载LIB库文件的三种方法

    VC中加载LIB库文件的三种方法 在VC中加载LIB文件的三种方法如下: 方法1:LIB文件直接加入到工程文件列表中   在VC中打开File View一页,选中工程名,单击鼠标右键,然后选中&quo ...

  4. Logstash处理json格式日志文件的三种方法

    假设日志文件中的每一行记录格式为json的,如: {"Method":"JSAPI.JSTicket","Message":"JS ...

  5. java将doc文件转换为pdf文件的三种方法

    http://feifei.im/archives/93 —————————————————————————————————————————————— 项目要用到doc转pdf的功能,一番google ...

  6. python面对对象编程------3:写集合类的三种方法

    写一个集合类的三种方法:wrap,extend,invent 一:包装一个集合类 class Deck: def __init__( self ): self._cards = [card6(r+1, ...

  7. Python实现下载文件的三种方法

    下面来看看三种方法是如何来下载zip文件的:方法一: import urllib print "downloading with urllib" url = 'http://www ...

  8. Viewing the interface of your Swift code,查看Swift代码的头文件的三种方法

      Technical Q&A QA1914 Viewing the interface of your Swift code Q:  How do I view the interface ...

  9. python下载文件的三种方法

    Python开发中时长遇到要下载文件的情况,最常用的方法就是通过Http利用urllib或者urllib2模块. 当然你也可以利用ftplib从ftp站点下载文件.此外Python还提供了另外一种方法 ...

随机推荐

  1. 【深入Java虚拟机】之四:类加载机制

    类加载过程     类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期包括:加载.验证.准备.解析.初始化.使用和卸载七个阶段.它们开始的顺序如下图所示: 其中类加载的过程包括了加载.验 ...

  2. [原创]关于Hibernate中的级联操作以及懒加载

    Hibernate: 级联操作 一.简单的介绍 cascade和inverse (Employee – Department) Casade用来说明当对主对象进行某种操作时是否对其关联的从对象也作类似 ...

  3. Flyweight(享元模式)

    import java.util.Hashtable; /** * 享元模式 * @author TMAC-J * 享元模式一般和工厂模式一起使用,但此处为了更好说明,只用享元模式 * 定义:享元模式 ...

  4. ABAP单元测试最佳实践

    本文包含了我在开发项目中经历过的实用的ABAP单元测试指导方针.我把它们安排成为问答的风格,欢迎任何人添加更多的Q&A's,以完成这个列表. 在我的项目中,只使用传统的ABAP report. ...

  5. H3 BPM初次安装常见错误详解1-4

    错误1: 首次安装完成无法访问,效果如下. 错误原因:没有配置IIS. 解决方法: 控制面板-程序-打开或关闭Windows功能,选择internet信息服务. 因为安装的时候没有没有iis,所以程序 ...

  6. Oracle常用SQL函数整理

    --返回ASCII码select  ASCII('A') "A的ASCII码" ,ASCII('a') "a的ASSCII码" from dual ; --反向 ...

  7. 第14章 Linux启动管理(2)_启动引导程序grub

    2. 启动引导程序grub 2.1 Grub配置文件 (1)grub中分区的表示 硬盘 分区 Linux设备文件名 Grub中设备文件名 第1块SCSI硬盘 第1个主分区 /dev/sda1 hd(0 ...

  8. Photoshop、Illustrator思维导图笔记

    半年前学习Photoshop时记得的思维导图笔记,可能不是很全,常用的基本都记下了.

  9. ASP.NET Core "完整发布,自带运行时" 到jexus

    一.阅读前须知   1.使用 jexus整合asp.net core的优点:       1)支持多站点,同一端口可以同时支持任何多的asp.net core应用程序:      2)应用程序启动.停 ...

  10. dynamic-css 动态 CSS 库,使得你可以借助 MVVM 模式动态生成和更新 css,从 js 事件和 css 选择器的苦海中脱离出来

    dynamic-css 使得你可以借助 MVVM 模式动态生成和更新 css,从而将本插件到来之前,打散.嵌套在 js 中的修改样式的代码剥离出来.比如你要做元素跟随鼠标移动,或者根据滚动条位置的变化 ...