base64编解码_迅雷链转换

1.base64

平时经常用到base64,但是没关注过具体的计算方法, 偶然 在网页源码里面看到 一段js:


////////////////////////////////////////////////////////////
var keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";

function encode64(input) {
	var output = "";
	var chr1, chr2, chr3 = "";
	var enc1, enc2, enc3, enc4 = "";
	var i = 0;
	do {
		chr1 = input.charCodeAt(i++);
		chr2 = input.charCodeAt(i++);
		chr3 = input.charCodeAt(i++);
		enc1 = chr1 >> 2;
		enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
		enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
		enc4 = chr3 & 63;
		if (isNaN(chr2)) {
			enc3 = enc4 = 64;
		} else if (isNaN(chr3)) {
			enc4 = 64;
		}
		output = output + keyStr.charAt(enc1) + keyStr.charAt(enc2) + keyStr.charAt(enc3) + keyStr.charAt(enc4);
		chr1 = chr2 = chr3 = "";
		enc1 = enc2 = enc3 = enc4 = "";
	} while ( i < input . length );
	return output;
}

function decode64(input) {
	var output = "";
	var chr1, chr2, chr3 = "";
	var enc1, enc2, enc3, enc4 = "";
	var i = 0;
	if (input.length % 4 != 0) {
		return "";
	}
	var base64test = /[^A-Za-z0-9\+\/\=]/g;
	if (base64test.exec(input)) {
		return "";
	}
	do {
		enc1 = keyStr.indexOf(input.charAt(i++));
		enc2 = keyStr.indexOf(input.charAt(i++));
		enc3 = keyStr.indexOf(input.charAt(i++));
		enc4 = keyStr.indexOf(input.charAt(i++));
		chr1 = (enc1 << 2) | (enc2 >> 4);
		chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
		chr3 = ((enc3 & 3) << 6) | enc4;
		output = output + String.fromCharCode(chr1);
		if (enc3 != 64) {
			output += String.fromCharCode(chr2);
		}
		if (enc4 != 64) {
			output += String.fromCharCode(chr3);
		}
		chr1 = chr2 = chr3 = "";
		enc1 = enc2 = enc3 = enc4 = "";
	} while ( i < input . length );
	return output;
}

base64 编码就是 直接把 8 位的字节流 换算成 6位的字节流, 然后用 A-Za-z0-9+/= 这65个字符依次表示这 6位字节流的,最末的=作为补足用的.

11110000   11110000    11110000

111100   001111  000011  110000

3字节*8bit = 4字节*6bit

从而 实现 取值为 0~255 的字符  到 可见字符的转换, 便于二进制数据 以文本形式存储.

base64_.png

 

2.迅雷链

另外是迅雷链转换 使用的就是 base64 编码, 利用写了一个简单的UI, 实现 方便的 转换操作.

主要实现 多行批量转换的支持, 过滤行首行尾 多余空格. 粘贴后 自动根据内容(是否是迅雷链格式)猜测需要编码还是解码.

迅雷链转换1.png

 

3.下载链接

迅雷链转换1.rar

4.后记

现代浏览器中 可以用 btoa, atob 函数进行base64编解码, 不过注意不支持中文.

ref: 次碳酸钴的博客_base64编码

btoa('hello')
atob('aGVsbG8=')


标签: javascript hta thunder

仅有一条评论 »

  1. 研究了下,按照算法,结尾的等号的数量有三种情况,0个,1个,2个.哈哈

添加新评论 »

贴图表情