前言
在前端开发中,经常会有需要分享文件的需求。但是,文件比较大或者格式不兼容时,直接分享文件并不方便,这时候我们需要一个工具来解决这个问题。filelinker 是一款可以将任意文件转换为网页链接的 npm 包,支持的文件格式包括文本、图片、视频等。
filelinker 除了可以将文件转换为链接,还支持二进制数据的压缩,将文件大小优化至最小。因此,使用 filelinker 可以让我们更加便捷地分享文件。
安装
首先,你需要在本地安装 node.js 环境,npm 包在 node.js 中。
安装 filelinker 非常简单,只需要在命令行输入以下命令即可:
npm install filelinker
使用
将文件转换为链接
将文件转换为链接非常简单,只需要调用 filelinker 中的 encode
方法,将文件路径作为参数传入即可:
const filelink = require("filelinker"); const filePath = "/Users/example/Desktop/example.txt"; const link = filelink.encode(filePath); console.log(link);
这里以将文本文件转换为链接为例,控制台输出的结果如下:
filelink://FgGwoBYsIMACQsImV4YW1wbGUiOiAiRGVjb2RlIiwgInRpbWUiOiAiMjAyMS0wNS0yMyAxNDowMTowMi4wNjI3MDIifQ==
将链接还原为文件
如果需要将链接还原为文件,也非常简单。只需要调用 filelinker 中的 decode
方法,将链接作为参数传入即可:
const filelink = require("filelinker"); const link = "filelink://FgGwoBYsIMACQsImV4YW1wbGUiOiAiRGVjb2RlIiwgInRpbWUiOiAiMjAyMS0wNS0yMyAxNDowMTowMi4wNjI3MDIifQ=="; const filePath = "/Users/example/Desktop/example_2.txt"; filelink.decode(link, filePath); console.log("文件还原成功!");
控制台输出 文件还原成功!
说明文件已经成功还原。
压缩二进制数据
filelinker 支持压缩二进制数据,将文件大小优化至最小。可以通过调用 compress
方法完成压缩操作:
const filelink = require("filelinker"); const filePath = "/Users/example/Desktop/example.png"; const data = filelink.read(filePath); const compressedData = filelink.compress(data); console.log(`原始数据大小: ${data.length}, 压缩后数据大小: ${compressedData.length}`);
控制台输出 原始数据大小: 1161017, 压缩后数据大小: 608751
,说明文件大小被优化至原来的 52.5%。
知识扩展
Base64
在介绍 filelinker 的机制之前,需要先介绍 Base64。
Base64 是一种用于将二进制数据编码的方式,可以将任意文件转换为包含 64 个字符的字符串。Base64 编码使用 ASCII 字符表中的字符,包括字母、数字和符号。由于 Base64 编码仅仅使用了 ASCII 字符表中的字符,因此可以在任何地方使用;而且编码后的字符串无须考虑传输中的二进制数据丢失问题。
filelinker 机制
当我们调用 encode
方法时,filelinker 的内部机制是这样的:
读取文件内容,并将文件内容压缩为二进制数据。
使用 Base64 对压缩后的二进制数据进行编码。
将编码后的数据和文件类型信息组合成一个 json 对象,再将该对象使用 Base64 编码。
将 json 对象的 Base64 编码结果再次包装为一个协议头
filelink://
加上协议体,组成最终的链接。
当我们调用 decode
方法时,filelinker 的内部机制是这样的:
解析链接中的 json 对象。
使用 Base64 对 json 对象中的数据进行解码,并获取文件类型和压缩过的二进制数据。
使用 Base64 对获取到的压缩过的二进制数据进行解码,得到原始数据。
将原始数据写入到指定的文件路径中。
总结
通过本文,我们了解到了 filelinker 的使用方法及其机制。filelinker 的确是个方便好用的 npm 包,它可以将任意文件都转化为简单易用的链接。希望本文对大家的学习和工作有一定的帮助。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/600673defb81d47349e53bf3