nodejs如何读取文件二进制 前端响应blob或base64显示图片

 更新时间:2022年08月03日 14:08:18   作者:坚持学习前端日记  
这篇文章主要介绍了nodejs如何读取文件二进制 前端响应blob或base64显示图片方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

读取文件二进制 前端响应blob或base64显示图片

express 框架 nodejs

var express = require('express')
var app = express();
var fs = require('fs')
var http = require('http').createServer(app);
app.get('/send',async (req, res) => {
  res.setHeader('Access-Control-Allow-Origin','*');
  function read () {
    return new Promise((resolve, rejects) => {
      fs.readFile('./public/2020.jpg',function(err, data) {
        resolve(data)
        rejects(err)
      })
    })
  }
  let data = await  read()
  res.send(data)
})
http.listen(3000, () => {
  console.log('listening on *:3000');
});app.get('/send',async (req, res) => {
  res.setHeader('Access-Control-Allow-Origin','*');
  function read () {
    return new Promise((resolve, rejects) => {
      fs.readFile('./public/2020.jpg',function(err, data) {
      // 可以更换不同文件 图片 或者 文档 等等 前端接受的时候 对应就ok
        resolve(data)
        rejects(err)
      })
    })
  }
  let data = await  read()
  res.send(data)
})
http.listen(3000, () => {
  console.log('listening on *:3000');
})

前端响应接受 使用了vue脚手架

<template>
  <div id="app">
    <img :src="src" alt="12">
  </div>
</template>
<script>
export default {
  data () {
    return {
      src: ''
    }
  },
  created () {
    function blobToDataURI (blob) {
          return new Promise((resolve, reject) => {
          let reader = new FileReader()
          reader.readAsDataURL(blob)//blob
          reader.onload = function (e) {
          resolve(e.target.result)//base64
      }
  })
  }
fetch('http://localhost:3000/send').then(x=>x.blob())
.then(async res=>{
  var body = document.body
 await blobToDataURI(res).then(reu => {
    this.src = reu // base64显示图片
  })
  //this.src = URL.createObjectURL(res) blob流显示图片
  console.log(URL.createObjectURL(res))
  var a = document.createElement('a')
  a.setAttribute('href', URL.createObjectURL(res))
  body.appendChild(a)
  //Blob {size: 50107, type: "application/octet-stream"}
  res 二进制blob
  a.setAttribute('download','1.jpg') // 1.jpg 是动态的 根据文件类型来取名
  a.click()
})
  }
}
</script>

精简版

function base (blob) {
      var read = new FileReader()
      read.readAsDataURL(blob)
      read.onload = function (x) {
        console.log(x.target.result)
        var body = document.body
      var a = document.createElement('a')
      a.setAttribute('download', '1.pdf')
      a.setAttribute('href', x.target.result)
      body.appendChild(a)
      a.click()
      }
    }
    fetch('http://localhost:3000/send').then(x => x.blob()).then(x => {
      console.log(x)
      var body = document.body
      var a = document.createElement('a')
      // var url = window.URL.createObjectURL(new Blob([x]))
      base(new Blob([x]))
      // a.setAttribute('download', '1.pdf')
      // a.setAttribute('href', url)
      // body.appendChild(a)
      // a.click()
    })

nodejs读取文件 createReadStream

参数:

  • 第一个参数:读取文件的路径
  • 第二个参数:highWaterMark 最高水位线,默认最多读取64K

读取的内容都是buffer类型

返回的结果是一个可读流的实例,是非流动模式–我们最后要转化为流动模式

let rs=fs.createReadStream('./1.txt',{highWaterMark:1})

设置最高水位线每次读取1k

let fs=require("fs");
// 第一个参数,读取文件的路径
//第二个参数 highWaterMark 最高水位线,默认最多读取64K
//读取的类容都是buffer类型
//返回的结果是一个可读流的实例,是非流动模式---我们最后要转为流动模式
// 转流动模式需要on事件监测
let rs=fs.createReadStream('./1.txt',{highWaterMark:1})
//在内部不断触发rs.emit('data',数据);data不能更改,留动模式开启后,数据会疯狂触发data事件
let arr=[];
rs.on('data',function (chunk) {  //chunk是buffer类型
    arr.push(chunk);
})
//监听文件读取完毕,会自动触发一次end事件,没有读取完是不会触发的
//Buffer.concat合并小buffer
rs.on('end',function (chunk) {
    
    console.log( Buffer.concat(arr).toString());
})
// 监听错误
rs.on('error',function (err) {
    console.log(err);
})
// rs.resume() 恢复读取
// rs.pause()  暂停读取
//这两个都控制是否继续触发data事件

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

相关文章

  • 完美解决node.js中使用https请求报CERT_UNTRUSTED的问题

    完美解决node.js中使用https请求报CERT_UNTRUSTED的问题

    下面小编就为大家带来一篇完美解决node.js中使用https请求报CERT_UNTRUSTED的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • Node.js利用console输出日志文件的方法示例

    Node.js利用console输出日志文件的方法示例

    本篇文章主要介绍了Node.js利用console输出日志文件的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • Node.js中常用文件系统操作的示例详解

    Node.js中常用文件系统操作的示例详解

    这篇文章将深入探讨 Node.js 中的文件系统(fs)模块,它是 Node.js 中进行文件读写的核心模块,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-02-02
  • node.js读取文件到字符串的方法

    node.js读取文件到字符串的方法

    这篇文章主要介绍了node.js读取文件到字符串的方法,涉及readFileSync方法的使用技巧,需要的朋友可以参考下
    2015-06-06
  • 使用Node操作MySQL的两种方式

    使用Node操作MySQL的两种方式

    本文将介绍如何在 Node.js 应用中使用 mysql2 和 TypeORM 两种方式操作 MySQL 数据库,文中通过代码示例介绍的非常详细,对大家的学习有一定的帮助,需要的朋友可以参考下
    2024-05-05
  • 给nodejs升级的两种方法

    给nodejs升级的两种方法

    nodejs是一种流行的服务器端JavaScript运行环境,它经常需要更新以获取最新的功能和性能优化,本文将给大家介绍了给nodejs升级的两种方法,文中通过代码示例讲解非常详细,需要的朋友可以参考下
    2023-12-12
  • nodejs前端模板引擎swig入门详解

    nodejs前端模板引擎swig入门详解

    这篇文章主要介绍了nodejs前端模板引擎swig入门详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • 用Node.js遍历多级目录处理文件的代码详解

    用Node.js遍历多级目录处理文件的代码详解

    在日常开发中,处理大量的文件操作是一个常见的需求,特别是在图像处理和存档管理领域,本文给大家介绍了如何用Node.js遍历多级目录处理文件,文章给出了主要步骤和完整代码,需要的朋友可以参考下
    2024-06-06
  • Windows7系统下如何安装nodejs16以上版本

    Windows7系统下如何安装nodejs16以上版本

    这篇文章主要给大家介绍了关于Windows7系统下如何安装nodejs16以上版本的相关资料,很多时候node.js的版本存在兼容,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • node.js通过axios实现网络请求的方法

    node.js通过axios实现网络请求的方法

    下面小编就为大家分享一篇node.js通过axios实现网络请求的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03

最新评论