var n=String.fromCharCode
var n = String.fromCharCode
是 JavaScript 的内置函数,它的作用是将一串包含Unicode编码的数字(通常是十六进制或十进制)转换成相应的字符。当你赋值给变量 n
这样的表达式,例如 n(\x35\x35)
或 n(55)
,它会返回对应于该 Unicode 编码字符的字符串。
举个例子,String.fromCharCode('a')
返回的是字符 'a',而 String.fromCharCode(97)
也是同样的效果,因为它们都代表小写字母 'a' 的 Unicode 编码。
如果你有一个包含多个十六进制数的字符串,如 \x35\x35
到 \x35\x30
,你可以像这样使用它:
var encryptedChars = '\x35\x35\x2c\x35\x36\x2c\x35\x34\x2c\x37\x39\x2c\x31\x31\x35\x2c\x36\x39\x2c\x31\x31\x34\x2c\x31\x31\x36\x2c\x31\x30\x37\x2c\x34\x39\x2c\x35\x30';
var decodedChars = String.fromCharCode(...encryptedChars.match(/.{2}/g)); // 将字符串拆分成两字节一组并转换
这里 match(/.{2}/g)
用于按每两个字符分组,然后传递给 String.fromCharCode
来解码。
/** * * Base64 encode / decode * http://www.webtoolkit.info/ * **/ var Base64 = { // private property _keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", // public method for encoding encode : function (input, binary) { binary = (binary != null) ? binary : false; var output = ""; var chr1, chr2, chr3, enc1, enc2, enc3, enc4; var i = 0; if (!binary) { input = Base64._utf8_encode(input); } while (i < input.length) { 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 + this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) + this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4); } return output; }, // public method for decoding decode : function (input, binary) { binary = (binary != null) ? binary : false; var output = ""; var chr1, chr2, chr3; var enc1, enc2, enc3, enc4; var i = 0; input = input.replace(/[^A-Za-z0-9\+\/\=]/g, ""); while (i < input.length) { enc1 = this._keyStr.indexOf(input.charAt(i++)); enc2 = this._keyStr.indexOf(input.charAt(i++)); enc3 = this._keyStr.indexOf(input.charAt(i++)); enc4 = this._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 = output + String.fromCharCode(chr2); } if (enc4 != 64) { output = output + String.fromCharCode(chr3); } } if (!binary) { output = Base64._utf8_decode(output); } return output; }, // private method for UTF-8 encoding _utf8_encode : function (string) { string = string.replace(/\r\n/g,"\n"); var utftext = ""; for (var n = 0; n < string.length; n++) { var c = string.charCodeAt(n); if (c < 128) { utftext += String.fromCharCode(c); } else if((c > 127) && (c < 2048)) { utftext += String.fromCharCode((c >> 6) | 192); utftext += String.fromCharCode((c & 63) | 128); } else { utftext += String.fromCharCode((c >> 12) | 224); utftext += String.fromCharCode(((c >> 6) & 63) | 128); utftext += String.fromCharCode((c & 63) | 128); } } return utftext; }, // private method for UTF-8 decoding _utf8_decode : function (utftext) { var string = ""; var i = 0; var c = c1 = c2 = 0; while ( i < utftext.length ) { c = utftext.charCodeAt(i); if (c < 128) { string += String.fromCharCode(c); i++; } else if((c > 191) && (c < 224)) { c2 = utftext.charCodeAt(i+1); string += String.fromCharCode(((c & 31) << 6) | (c2 & 63)); i += 2; } else { c2 = utftext.charCodeAt(i+1); c3 = utftext.charCodeAt(i+2); string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63)); i += 3; } } return string; } }
这段代码是一个用于Base64编码和解码的工具类。它提供了两个方法:encode和decode。encode方法用于将输入的字符串进行Base64编码,decode方法用于将Base64编码的字符串解码为原始字符串。
在encode方法中,首先判断是否需要将输入字符串转换为UTF-8编码。然后,通过循环遍历输入字符串的每一个字符,将字符转换为对应的ASCII码,并根据Base64编码规则进行编码。最后,将编码后的字符拼接到输出字符串中,并返回最终的编码结果。
在decode方法中,首先移除输入字符串中的非Base64字符。然后,通过循环遍历输入字符串的每四个字符,根据Base64解码规则将字符转换为对应的ASCII码,并将解码后的字符拼接到输出字符串中。最后,如果不是二进制输出,将输出字符串转换为UTF-8编码,并返回最终的解码结果。
此外,还有两个私有方法:_utf8_encode和_utf8_decode用于将字符串转换为UTF-8编码和从UTF-8编码转换回原始字符串。
这个工具类可以在前端或后端使用,用于处理Base64编码和解码的需求。
解释代码 function urlEncode(str) { let strArr = []; let output = ''; strArr = Array.from(str); for (let v of strArr) { let regRule = /\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/g; output += v.match(regRule) ? encodeURIComponent(v) : encodeNoEmoji(v); } return output; } function encodeNoEmoji(str) { var output = ''; var x = 0; str = utf16to8(str.toString()); var regex = /(^[a-zA-Z0-9-_.]*)/; while (x < str.length) { var match = regex.exec(str.substr(x)); if (match !== null && match.length > 1 && match[1] !== '') { output += match[1]; x += match[1].length; } else { if (str[x] === ' ') output += '+'; else { var charCode = str.charCodeAt(x); var hexVal = charCode.toString(16); output += '%' + ( hexVal.length < 2 ? '0' : '' ) + hexVal.toUpperCase(); } x++; } } return output; } function utf16to8(str) { var out, i, len, c; out = ""; len = str.length; for(i = 0; i < len; i++) { c = str.charCodeAt(i); if ((c >= 0x0001) && (c <= 0x007F)) { out += str.charAt(i); } else if (c > 0x07FF) { out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F)); out += String.fromCharCode(0x80 | ((c >> 6) & 0x3F)); out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F)); } else { out += String.fromCharCode(0xC0 | ((c >> 6) & 0x1F)); out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F)); } } return out; }
这段代码实现了一个函数 urlEncode
,将给定的字符串进行 URL 编码。具体来说,它会将字符串中的非 ASCII 字符进行编码,同时保留空格和一些特殊字符(例如 -
、.
、_
)。其中 encodeNoEmoji
函数实现了非 ASCII 字符的编码,它会先将字符串转换成 UTF-8 编码,然后根据 ASCII 码表对不同字符进行编码。除此之外,还有一个特殊处理,即对表情符号进行编码,因为表情符号的编码方式与普通字符不同。这里使用了正则表达式来匹配表情符号,如果匹配到则使用 encodeURIComponent
函数进行编码,否则调用 encodeNoEmoji
函数进行编码。最后,将所有编码后的字符拼接在一起,返回编码后的字符串。
相关推荐
















