javascript - 这是个什么问题?没毛病啊感觉
伊谢尔伦
伊谢尔伦 2017-04-11 12:30:10
[JavaScript讨论组]

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(3)
PHP中文网

1.直接的bug就是1楼的同学说的
2.但是你在读文件的时候没用到流,所以我觉得你可以直接使用_this.res.end(data)可以避免你的问题
3.从你的代码中读出来几点意见给你

  • fs.exists(path, callback)这个方法很早就已经Deprecated了,所以也不推荐你使用,用 fs.lstat() or fs.access()代替吧!

  • 既然你想用write,那你读文件的时候就可以用流去读,这样如果是一个超大的文件的话,你就可以流式读取的方式读出来,你现在readFile,然后直接write,最后end,还是一次性把文件内容读到内存中,对于大文件来说还是体验很差,推荐使用下面的代码尝试一下

  const filePath=path.join(__dirname, 'xxxx.json')
  fs.lstat(filePath, (err, stats) => {
    if(err) return res.status(500).end('file is not founded')
    res.writeHead(200, {
      'Content-Type' : 'application/json',
    })
    const readStream = fs.createReadStream(filePath)
    readStream.on('end', () => {
      res.end()
    })
    readStream.on('error', (error) => {
      res.end(`read file stream error ${error.message}`)
    })
    readStream.pipe(res)
  })

随手写了一些, 你可以进行优化,打日志,或者用async解决callback hell问题等,还有头类型,返回的错误信息等,不过核心的流式吐出的代码应该没问题,仅供参考,希望对你有帮助

高洛峰

res.write()是异步的,所以上面代码执行书序是res.end()之后才真的是write。你可以在write的回调中调用end

天蓬老师

res.on('finish', res.end) 试一下

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号