【问题标题】:Encode and decode skipping the characters编码和解码跳过字符
【发布时间】:2018-07-10 09:36:09
【问题描述】:

我正在尝试使用它们的编码格式将一些字符串存储到数据库中。但是当检索回来时,字符串格式不正确。

这是我的代码示例,您可以轻松地看到传递给编码的字符串与解码后的字符串不同。为什么会这样?

有没有其他库可以帮助我编码和解码?任何相同的建议都会有所帮助。

var Base64 = {
	_keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
	encode : function(e) {
		var t = "";
		var n, r, i, s, o, u, a;
		var f = 0;
		e = Base64._utf8_encode(e);
		while (f < e.length) {
			n = e.charCodeAt(f++);
			r = e.charCodeAt(f++);
			i = e.charCodeAt(f++);
			s = n >> 2;
			o = (n & 3) << 4 | r >> 4;
			u = (r & 15) << 2 | i >> 6;
			a = i & 63;
			if (isNaN(r)) {
				u = a = 64
			} else if (isNaN(i)) {
				a = 64
			}
			t = t + this._keyStr.charAt(s) + this._keyStr.charAt(o)
					+ this._keyStr.charAt(u) + this._keyStr.charAt(a)
		}
		return t
	},
	decode : function(e) {
		var t = "";
		var n, r, i;
		var s, o, u, a;
		var f = 0;
		e = e.replace(/[^A-Za-z0-9+/=]/g, "");
		while (f < e.length) {
			s = this._keyStr.indexOf(e.charAt(f++));
			o = this._keyStr.indexOf(e.charAt(f++));
			u = this._keyStr.indexOf(e.charAt(f++));
			a = this._keyStr.indexOf(e.charAt(f++));
			n = s << 2 | o >> 4;
			r = (o & 15) << 4 | u >> 2;
			i = (u & 3) << 6 | a;
			t = t + String.fromCharCode(n);
			if (u != 64) {
				t = t + String.fromCharCode(r)
			}
			if (a != 64) {
				t = t + String.fromCharCode(i)
			}
		}
		t = Base64._utf8_decode(t);
		return t
	},
	_utf8_encode : function(e) {
		e = e.replace(/rn/g, "n");
		var t = "";
		for (var n = 0; n < e.length; n++) {
			var r = e.charCodeAt(n);
			if (r < 128) {
				t += String.fromCharCode(r)
			} else if (r > 127 && r < 2048) {
				t += String.fromCharCode(r >> 6 | 192);
				t += String.fromCharCode(r & 63 | 128)
			} else {
				t += String.fromCharCode(r >> 12 | 224);
				t += String.fromCharCode(r >> 6 & 63 | 128);
				t += String.fromCharCode(r & 63 | 128)
			}
		}
		return t
	},
	_utf8_decode : function(e) {
		var t = "";
		var n = 0;
		var r = c1 = c2 = 0;
		while (n < e.length) {
			r = e.charCodeAt(n);
			if (r < 128) {
				t += String.fromCharCode(r);
				n++
			} else if (r > 191 && r < 224) {
				c2 = e.charCodeAt(n + 1);
				t += String.fromCharCode((r & 31) << 6 | c2 & 63);
				n += 2
			} else {
				c2 = e.charCodeAt(n + 1);
				c3 = e.charCodeAt(n + 2);
				t += String.fromCharCode((r & 15) << 12 | (c2 & 63) << 6 | c3
						& 63);
				n += 3
			}
		}
		return t
	}
}


var str = "background:url(/drona-courses/player_assets/skin_0/DRONA_default_skinRightCorner.png) ;"

var encoded = Base64.encode(str);
//console.log(encoded);

var decoded = Base64.decode(encoded);
console.log(str,"......Input");
console.log(decoded,".....Output");

【问题讨论】:

  • 您不需要自己的 Base64 函数。您可以改用内置的atobbtoa
  • 你能给我一个工作的例子吗?

标签: javascript html base64 decode encode


【解决方案1】:

Base64 Encoding in common browsers

在JavaScript中有两个函数分别用于base64字符串的解码和编码:

atob()

btoa()

atob() 函数对使用 base-64 编码的数据字符串进行解码。相反,btoa() 函数从二进制数据“字符串”创建一个 base-64 编码的 ASCII 字符串。

【讨论】:

    【解决方案2】:

    使用atobbtoa

    const foo = "bar"
    
    const encodedFoo = btoa(foo)
    const decodedFoo = atob(encodedFoo)
    
    console.log(encodedFoo)
    console.log(decodedFoo)

    您可以阅读更多关于它的信息here.

    【讨论】:

    • 谢谢,它有效,但如果你能解释你给定方法背后的逻辑。我的代码有什么问题那么我会接受这个答案
    • 我不确定你想让我解释什么,这些函数是内置在 JavaScript 中的。至于你的代码,我不知道,对于任何开发人员来说,理解使用一个字母变量名的代码通常都不是一件容易的事。
    • 我真的明白了,非常感谢您的回复。这让我很开心。
    猜你喜欢
    • 2012-07-05
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-03-25
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多