ftpclient.storefile 返回true 文件传输不完整_Node.js 缓冲区的完整指南

本文详细介绍了Node.js的Buffer模块,包括其方法如创建缓冲区、比较、连接、填充等。文章指出在FTP客户端使用storeFile返回true时,可能存在文件传输不完整的问题,并提示理解Buffer及其工作原理对于有效处理二进制数据至关重要。
摘要由CSDN通过智能技术生成

0e3bcbc437d1022492e8bed6943f8a9d.png
  • 原文地址:A Complete Guide of Node.js Buffer
  • 原文作者:Harsh Patel
  • 译文出自:掘金翻译计划
  • 本文永久链接:https://github.com/xitu/gold-miner/blob/master/article/2021/a-complete-guide-of-node-js-buffer.md
  • 译者:苏苏的 PassionPenguin
  • 校对者:flashhu 与 regon-cao

Node.js 缓冲区的完整指南

二进制流是大量的二进制数据的集合。由于它们的大小很大,因此二进制流不会一起运送,而会在运输前分成小块然后逐一发送。

当数据处理单元不接受其他数据流时,剩余的数据将保留在缓存中,直到数据处理单元准备好接收更多数据为止。

Node.js 服务器通常需要在文件系统中进行读写。当然,文件存储在二进制文件中。此外,Node.js 会与 TCP 流一起使用,让 TCP 流在将二进制数据分成小块传输前保证了接收方的通信。

发送给接收者的数据流需要缓冲,直到接收者准备接收更多要处理的数据为止。这就是 Node.js 处理临时数据部分的工作内容 —— 在 V8 引擎外部管理和存储二进制数据。

让我们一起深入缓冲区(Buffer)的各种使用方法,了解更多有关它们的信息以及一起学习如何在 Node.js 程序中使用它们吧。

ddb34286a17c0c630813b8f8d93d7ba6.png

Node.js Buffer 的方法

Node.js 缓冲模块的优点是它内置于 Node.js 中,因此您可以在任何地方使用它。

让我们一起浏览一些重要的 Node.js 缓冲模块的方法吧。

Buffer.alloc()

此方法将创建一个新的缓冲区,但是分配的大小不是固定的。当您调用此方法时,可以自行分配大小(以字节为单位)。

const buf = Buffer.alloc(6)  // 这会创建一个 6 字节的缓冲区

console.log(buf) // <Buffer 00 00 00 00 00 00>

Buffer.byteLength()

现在,如果要获取缓冲区的长度,则只需调用 Buffer.byteLength()

var buf = Buffer.alloc(10)
var buffLen = Buffer.byteLength(buf) // 检查缓冲区长度

console.log(buffLen)// <10>

Buffer.compare()

通过使用 Buffer.compare() 您可以比较两个缓冲区,此方法的返回值是 -101 中的一个

译者注:

buf.compare(otherBuffer);

该方法会返回一个数字,表示 buf 在 otherBuffer 之前,之后或相同。

var buf1 = Buffer.from('Harsh')
var buf2 = Buffer.from('Harsg')
var a = Buffer.compare(buf1, buf2)
console.log(a) // 这会打印 0

var buf1 = Buffer.from('a')
var buf2 = Buffer.from('b')
var a = Buffer.compare(buf1, buf2)
console.log(a) // 这会打印 -1


var buf1 = Buffer.from('b')
var buf2 = Buffer.from('a')
var a = Buffer.compare(buf1, buf2)
console.log(a) // 这会打印 1

Buffer.concat

顾名思义,您可以使用此方法连接两个缓冲区。当然,就像字符串一样,您也可以连接两个以上的缓冲区。

var buffer1 = Buffer.from('x')
var buffer2 = Buffer.from('y')
var buffer3 = Buffer.from('z')
var arr = [buffer1, buffer2, buffer3]

console.log(arr)
/* buffer, !concat [ <Buffer 78>, <Buffer 79>, <Buffer 7a> ] */

// 通过 Buffer.concat 方法连接两个缓冲区
var buf = Buffer.concat(arr)

console.log(buf)
// <Buffer 78 79 7a> concat successful

Buffer.entries()

Buffer.entries() 会用这一缓冲区的内容创建并返回一个 [index, byte] 形式的迭代器。

var buf = Buffer.from('xyz')

for (a of buf.entries()) {
  console.log(a)
  /* 这个会在控制台输出一个有缓冲区位置与内容的字节的数组 [ 0, 120 ][ 1, 121 ][ 2, 122 ]*/
}

Buffer.fill()

顾名思义,您可以使用 Buffer.fill() 方法将数据插入或填充到缓冲区中。更多信息请参见下文。

const b = Buffer.alloc(10).fill('a')

console.log(b.toString())
// aaaaaaaaaa

Buffer.includes()

像字符串一样,它将确认缓冲区是否具有该值。您可以使用 Buffer.includes() 方法来实现这一点,给定方法根据搜索返回一个布尔值,即 truefalse

const buf = Buffer.from('this is a buffer')
console.log(buf.includes('this'))
// true

console.log(buf.includes(Buffer.from('a buffer example')))
// false

Buffer.isEncoding()

您可能知道二进制文件必须进行编码,如果您要检查数据类型是否支持字符编码?您可以使用 Buffer.isEncoding() 方法进行确认。如果支持,它将返回 true

console.log(Buffer.isEncoding('hex'))
// true

console.log(Buffer.isEncoding('utf-8'))
// true

console.log(Buffer.isEncoding('utf/8'))
// false

console.log(Buffer.isEncoding('hey'))
// false

Buffer.slice()

buf.slice() 将用于使用缓冲区的选定元素创建一个新缓冲区 —— 对缓冲区进行切割时,将创建一个新缓冲区,其中包含要在新缓冲区切片中找到的项目的列表。

var a = Buffer.from('uvwxyz');
var b = a.slice(2,5);

console.log(b.toString());
// wxy

Buffer.swapX()

Buffer.swapX() 用于交换缓冲区的字节顺序。使用 Buffer.swapX() (此处 X 可以为 16, 32, 64)来交换16位,32位和64位缓冲区对象的字节顺序。

const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8])
console.log(buf1)
// <Buffer 01 02 03 04 05 06 07 08>

// 交换 16 位字节顺序
buf1.swap16()
console.log(buf1)
// <Buffer 02 01 04 03 06 05 08 07>

// 交换 32 位字节顺序
buf1.swap32()
console.log(buf1)
// <Buffer 03 04 01 02 07 08 05 06>

// 交换 64 位字节顺序
buf1.swap64()
console.log(buf1)
// <Buffer 06 05 08 07 02 01 04 03>

Buffer.json()

它可以帮助您从缓冲区创建 JSON 对象,而该方法将返回 JSON 缓冲区对象,

const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);

console.log(buf.toJSON());
// {"type":"Buffer", data:[1,2,3,4,5,6,7,8]}

结论

如果您需要进一步了解并使用 Node.js 的缓冲区,您需要对缓冲区以及 Node.js 缓冲区的工作原理有更扎实的基础知识。您还应该了解为什么我们需要使用 Node.js 缓冲区和各种 Node.js 缓冲区方法的使用。

如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。

掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 Android、iOS、前端、后端、区块链、产品、设计、人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划、官方微博、知乎专栏。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ftpclient.storefileFTPClient类中的一个方法,用于将本地文件上传到FTP服务器上。 具体用法如下: 1. 首先创建一个FTPClient对象,并连接到FTP服务器。 2. 然后使用storefile方法上传文件,该方法需要传入两个参数:远程文件名和本地文件名。 3. 上传完成后,关闭FTP连接。 示例代码: ``` FTPClient ftpClient = new FTPClient(); ftpClient.connect("ftp.example.com"); ftpClient.login("username", "password"); File localFile = new File("localfile.txt"); InputStream inputStream = new FileInputStream(localFile); ftpClient.storeFile("remotefile.txt", inputStream); inputStream.close(); ftpClient.logout(); ftpClient.disconnect(); ``` 以上代码将本地文件localfile.txt上传到FTP服务器上,并将其命名为remotefile.txt。 ### 回答2: FTPClientJava中常用的FTP客户端连接工具,其中ftpclient.storefileFTPClient上传文件方法之一。 使用ftpclient.storefile进行上传文件,首先需要创建一个FTP连接,并使用FTPClient的login方法进行登录。然后,需要设置上传文件的相关参数,包括上传文件的路径、文件名、上传模式等。 在设置好相关参数之后,调用ftpclient.storefile方法即可上传文件到指定的FTP服务器中。上传文件的过程需要关注的是上传进度、异常处理和上传结果的返回值。FTPClient中提供了多种方法来获取上传进度、处理异常和获得上传结果。 需要注意的是,在上传文件的过程中,我们需要保证文件名和上传路径的正确性,避免出现上传路径不存在或文件名重复等问题。同时,也需要检查上传文件的访问权限,确保上传文件的可读性和可写性。 总之,ftpclient.storefile方法Java上传文件FTP服务器的重要方法,使用时需要注意设置上传参数并处理相关异常,以确保文件能够正确地上传到FTP服务器中。 ### 回答3: FTPClientJava中常用的FTP客户端库,可以连接到FTP服务器并执行各种FTP操作。其中,storefileFTPClient中用来上传文件方法storefile的基本用法是将本地文件上传到FTP服务器中指定的路径下。使用该方法需要执行以下步骤: 1. 连接到FTP服务器。可以通过FTPClient的connect方法连接FTP服务器,需要指定服务器的主机地址、端口号、用户名和密码等信息。 2. 设置传输模式。FTPClient支持两种传输模式:二进制传输和ASCII传输。通过设置FTPClient的setFileType方法来指定传输模式,一般情况下使用二进制传输。 3. 设置工作目录。使用FTPClient的changeWorkingDirectory方法FTP服务器的当前工作目录切换到要上传文件的目录。 4. 执行上传操作。调用FTPClientstoreFile方法上传文件。需要指定本地文件的路径和文件名,以及上传后保存在FTP服务器中的文件名。 5. 关闭连接。上传完成后,使用FTPClient的disconnect方法关闭与FTP服务器之间的连接。 以下是storefile方法的代码示例: ``` FTPClient ftpClient = new FTPClient(); ftpClient.connect("ftp.example.com", 21); ftpClient.login("username", "password"); ftpClient.setFileType(FTP.BINARY_FILE_TYPE); ftpClient.changeWorkingDirectory("/upload"); File localFile = new File("localfile.txt"); InputStream inputStream = new FileInputStream(localFile); ftpClient.storeFile("uploadedfile.txt", inputStream); inputStream.close(); ftpClient.logout(); ftpClient.disconnect(); ``` 在实际使用中,还需要处理上传文件失败的情况,并且考虑到网络传输中可能出现的稳定性问题,需要进行断点续传等操作。对于大文件的上传,可以考虑使用多线程或分片上传等技术来提高上传效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值