SphinxJS - 把字符串加密成 png 图片的超轻量级开源库

3,124 阅读1分钟

体 验地址:jrainlau.github.io/sp...
项目地址:github.com/jrainlau/s.…

SphinxJS

一个能够把字符串加密成png图片,或者从png图片解密出字符串的超轻量级开源库,总代码数甚至不超过100行!

使用方法

通过npm安装

npm install sphinx.js

通过标签引入

值得注意的是,因为SphinxJS使用了ES2015的Promise以及其他很棒的特性,这意味着需要你的浏览器提供支持。否则的话,你可能需要Babel或者一些别的工具去构建你的代码。

SphinxJS同时支持以AMDCommonJS以及ES6模块的方式进行引用。

加密

定义一个字符串Hello Sphinx!,我们将对它进行加密

let base64URL = new Sphinx().encrypt('Hello Sphinx!')

然后你将得到一串base64编码

data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAADCAYAAABWKLW/AAAAJklEQVQYV2P0SM35r8K1heE5owcDY2Zexf8dc1Yw/BdjYGBkQAIA+r4JjQKvLx4AAAAASUVORK5CYII=

到这一步,加密便已经完成了。

正如你所看到的那样,encrypt()方法返回一张图片的base64编码。

Decrypt

定义一串图片的url:

let url = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAADCAYAAABWKLW/AAAAJklEQVQYV2P0SM35r8K1heE5owcDY2Zexf8dc1Yw/BdjYGBkQAIA+r4JjQKvLx4AAAAASUVORK5CYII='

然后我们对其进行解密!

new Sphinx().decrypt(url)
    .then((info) => {
        console.log(info) // Hello Sphinx!
    })

decrypt()方法会返回一个Promise对象,它包含了从图片中解密出来的字符串信息。

配置

new Sphinx()能够接收一个用于定义图片类型的配置对象

  • config {Object} 可选 默认值: {img: 'png'}

new Sphinx({img: 'bmp'})

证书

MIT