SphinxJS——把字符串编码成png图片的超轻量级开源库
体验地址:https://jrainlau.github.io/sp...
项目地址:https://github.com/jrainlau/s...
SphinxJS
一个能够把字符串编码成png图片,或者从png图片中解码出字符串的超轻量级开源库,总代码数甚至不超过100行!
使用方法
通过npm安装
npm install sphinx.js通过<script></script>标签引入
<script src="sphinx.js"></script>值得注意的是,因为
SphinxJS使用了ES2015的Promise以及其他很棒的特性,这意味着需要你的浏览器提供支持。否则的话,你可能需要Babel或者一些别的工具去构建你的代码。
SphinxJS同时支持以AMD,CommonJS以及ES6模块的方式进行引用。
编码
定义一个字符串Hello Sphinx!,我们将对它进行编码
let base64URL = new Sphinx().encode('Hello Sphinx!')然后你将得到一串base64编码
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAADCAYAAABWKLW/AAAAJklEQVQYV2P0SM35r8K1heE5owcDY2Zexf8dc1Yw/BdjYGBkQAIA+r4JjQKvLx4AAAAASUVORK5CYII=到这一步,编码便已经完成了。
正如你所看到的那样,encode()方法返回一张图片的base64编码。
解码
定义一串图片的url:
let url = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAADCAYAAABWKLW/AAAAJklEQVQYV2P0SM35r8K1heE5owcDY2Zexf8dc1Yw/BdjYGBkQAIA+r4JjQKvLx4AAAAASUVORK5CYII='然后我们对其进行解码!
new Sphinx().decode(url)
    .then((info) => {
        console.log(info) // Hello Sphinx!
    })decode()方法会返回一个Promise对象,它包含了从图片中解密出来的字符串信息。
配置
new Sphinx()能够接收一个用于定义图片类型的配置对象
- config {Object} - 可选默认值:- {img: 'png'}
new Sphinx({img: 'bmp'})证书
MIT
SphinxJS——把字符串编码成png图片的超轻量级开源库的更多相关文章
- js 字符串编码转换函数
		escape 方法 对 String 对象编码以便它们能在所有计算机上可读, escape(charString) 必选项 charstring 参数是要编码的任意 String 对象或文字. 说明 ... 
- C# 在网页中将Base64编码的字符串显示成图片
		在写一个接口,返回的json里面有图片,是Base64编码的字符串. 测试接口的时候,发现原来在html显示,是直接可以将Base64编码的字符串显示成图片的. 格式如下: <img src=d ... 
- Gson字符串编码,字符串转换成图片保存,二进制转换成图片保存
		import java.io.BufferedInputStream; import java.io.ByteArrayInputStream; import java.io.File; import ... 
- 图片和base64编码字符串 互相转换,图片和byte数组互相转换
		图片和base64编码字符串 互相转换 import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; import java.io.*; ... 
- base64字符串转化成图片
		package com.dhht.wechat.util; import sun.misc.BASE64Decoder;import sun.misc.BASE64Encoder; import ja ... 
- UTF-8编码的字符串拆分成单字、获取UTF-8字符串的字符个数的代码及原理
		一.字符编码简介 1. ASCII码 在计算机内部,所有的信息最终都表示为一个二进制的字符串.每一个二进制位(bit)有0和1两种状态,因此八个二进制位就可以组合出256种状态,这被称为一个字节(by ... 
- C# Base64字符串转换成图片及图片转换为Base64
		最近有朋友经常会问我一些问题,例如,如何把一个字符串转换成base64字符串,如何把一个二进制文件转换成Base64文件,以及如何转换回原有的文件,在此我把方法写一下 字符串与Base64相互转换 ... 
- WPF GDI+字符串绘制成图片(二)
		原文:WPF GDI+字符串绘制成图片(二) 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/BYH371256/article/details/83 ... 
- WPF  GDI+字符串绘制成图片(一)
		原文:WPF GDI+字符串绘制成图片(一) 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/BYH371256/article/details/83 ... 
随机推荐
- 数据库连接池与SQL工具类
			数据库连接池与SQL工具类 1.数据库连接池 依赖包 pymysql dbutils # -*- coding: utf-8 -*- ''' @Time : 2021/11/19 16:45 @Aut ... 
- LeetCode-047-全排列 II
			全排列 II 题目描述:给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列. 示例说明请见LeetCode官网. 来源:力扣(LeetCode) 链接:https://lee ... 
- mysql 获取当前时间和时间戳
			mysql 获取当前时间为select now()运行结果: 2012-09-05 17:24:15 mysql 获取当前时间戳为select unix_timestamp(now()) 运行结果:u ... 
- 一比一还原axios源码(零)—— 概要
			从vue2版本开始,vue-resource就不再被vue所维护和支持,官方也推荐使用axios,所以,从我使用axios至今,差不多有四五年了,这四五年的时间只能算是熟练应用,很多内部的实现和原理不 ... 
- 201922904李龙威 2019-2020-2 《Python程序设计》实验二报告
			20192204 2019-2020-2 <Python程序设计>实验二报告 课程:<Python程序设计> 班级: 1922 姓名: 李龙威 学号:20192204 实验教师 ... 
- Net Framework 中托管代码与非托管代码的区别
			托管代码与非托管代码的区别 1 简单的说,就是代码被编译成MSIL后在.net的Framework下运行,同操作系统底层的交互都交给framework去做. 所谓非托管代码就是脱离了Framework ... 
- 通过Geth搭建私有以太坊网络
			前言 为了进一步了解以太坊区块链网络的工作方式和运行原理,笔者通过官方软件Geth搭建了私有以太坊网络fantasynetwork,最终实现了单机和多机节点间的相互连通:首先通过VMware Work ... 
- 分布式搜索引擎Elasticsearch的架构分析
			一.写在前面 ES(Elasticsearch下文统一称为ES)越来越多的企业在业务场景是使用ES存储自己的非结构化数据,例如电商业务实现商品站内搜索,数据指标分析,日志分析等,ES作为传统关系型数据 ... 
- Java基础——final、static关键字
			final关键字是最终的意思,可以修饰成员方法.成员变量.类 特点: 1.修饰方法:表示该方法是最终方法,不能被重写 2.修饰变量:表示变量是常量,不能再次被赋值 3.修饰类:表示类是最终类,不能被继 ... 
- How to Rebase Git Branch
			转自:How to Rebase Git Branch (with 3 steps) | Git Rebase | W3Docs Steps to rebasing branch Fetching c ... 
