摘要:因為項目需求,需要處理編碼,再次記錄,便于之后調(diào)用關(guān)于的本質(zhì)就是把每位的編碼變成另外一個每位的編碼,用另外一個參照表進(jìn)行對應(yīng)翻譯。
因為項目需求,需要處理base64編碼,再次記錄,便于之后調(diào)用 關(guān)于base64:
base64的本質(zhì)就是把每8位的ASCII編碼變成另外一個每6位的編碼,用另外一個參照表進(jìn)行對應(yīng)翻譯。
以下為base64的js:
var Base64 = { // 轉(zhuǎn)碼表 table : [ "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O" ,"P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "+", "/" ], UTF16ToUTF8 : function(str) { var res = [], len = str.length; for (var i = 0; i < len; i++) { var code = str.charCodeAt(i); if (code > 0x0000 && code <= 0x007F) { // 單字節(jié),這里并不考慮0x0000,因為它是空字節(jié) // U+00000000 – U+0000007F 0xxxxxxx res.push(str.charAt(i)); } else if (code >= 0x0080 && code <= 0x07FF) { // 雙字節(jié) // U+00000080 – U+000007FF 110xxxxx 10xxxxxx // 110xxxxx var byte1 = 0xC0 | ((code >> 6) & 0x1F); // 10xxxxxx var byte2 = 0x80 | (code & 0x3F); res.push( String.fromCharCode(byte1), String.fromCharCode(byte2) ); } else if (code >= 0x0800 && code <= 0xFFFF) { // 三字節(jié) // U+00000800 – U+0000FFFF 1110xxxx 10xxxxxx 10xxxxxx // 1110xxxx var byte1 = 0xE0 | ((code >> 12) & 0x0F); // 10xxxxxx var byte2 = 0x80 | ((code >> 6) & 0x3F); // 10xxxxxx var byte3 = 0x80 | (code & 0x3F); res.push( String.fromCharCode(byte1), String.fromCharCode(byte2), String.fromCharCode(byte3) ); } else if (code >= 0x00010000 && code <= 0x001FFFFF) { // 四字節(jié) // U+00010000 – U+001FFFFF 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx } else if (code >= 0x00200000 && code <= 0x03FFFFFF) { // 五字節(jié) // U+00200000 – U+03FFFFFF 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx } else /** if (code >= 0x04000000 && code <= 0x7FFFFFFF)*/ { // 六字節(jié) // U+04000000 – U+7FFFFFFF 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx } } return res.join(""); }, UTF8ToUTF16 : function(str) { var res = [], len = str.length; var i = 0; for (var i = 0; i < len; i++) { var code = str.charCodeAt(i); // 對第一個字節(jié)進(jìn)行判斷 if (((code >> 7) & 0xFF) == 0x0) { // 單字節(jié) // 0xxxxxxx res.push(str.charAt(i)); } else if (((code >> 5) & 0xFF) == 0x6) { // 雙字節(jié) // 110xxxxx 10xxxxxx var code2 = str.charCodeAt(++i); var byte1 = (code & 0x1F) << 6; var byte2 = code2 & 0x3F; var utf16 = byte1 | byte2; res.push(Sting.fromCharCode(utf16)); } else if (((code >> 4) & 0xFF) == 0xE) { // 三字節(jié) // 1110xxxx 10xxxxxx 10xxxxxx var code2 = str.charCodeAt(++i); var code3 = str.charCodeAt(++i); var byte1 = (code << 4) | ((code2 >> 2) & 0x0F); var byte2 = ((code2 & 0x03) << 6) | (code3 & 0x3F); var utf16 = ((byte1 & 0x00FF) << 8) | byte2 res.push(String.fromCharCode(utf16)); } else if (((code >> 3) & 0xFF) == 0x1E) { // 四字節(jié) // 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx } else if (((code >> 2) & 0xFF) == 0x3E) { // 五字節(jié) // 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx } else /** if (((code >> 1) & 0xFF) == 0x7E)*/ { // 六字節(jié) // 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx } } return res.join(""); }, encode : function(str) { if (!str) { return ""; } var utf8 = this.UTF16ToUTF8(str); // 轉(zhuǎn)成UTF8 var i = 0; // 遍歷索引 var len = utf8.length; var res = []; while (i < len) { var c1 = utf8.charCodeAt(i++) & 0xFF; res.push(this.table[c1 >> 2]); // 需要補(bǔ)2個= if (i == len) { res.push(this.table[(c1 & 0x3) << 4]); res.push("=="); break; } var c2 = utf8.charCodeAt(i++); // 需要補(bǔ)1個= if (i == len) { res.push(this.table[((c1 & 0x3) << 4) | ((c2 >> 4) & 0x0F)]); res.push(this.table[(c2 & 0x0F) << 2]); res.push("="); break; } var c3 = utf8.charCodeAt(i++); res.push(this.table[((c1 & 0x3) << 4) | ((c2 >> 4) & 0x0F)]); res.push(this.table[((c2 & 0x0F) << 2) | ((c3 & 0xC0) >> 6)]); res.push(this.table[c3 & 0x3F]); } return res.join(""); }, decode : function(str) { if (!str) { return ""; } var len = str.length; var i = 0; var res = []; while (i < len) { code1 = this.table.indexOf(str.charAt(i++)); code2 = this.table.indexOf(str.charAt(i++)); code3 = this.table.indexOf(str.charAt(i++)); code4 = this.table.indexOf(str.charAt(i++)); c1 = (code1 << 2) | (code2 >> 4); res.push(String.fromCharCode(c1)); if (code3 != -1) { c2 = ((code2 & 0xF) << 4) | (code3 >> 2); res.push(String.fromCharCode(c2)); } if (code4 != -1) { c3 = ((code3 & 0x3) << 6) | code4; res.push(String.fromCharCode(c3)); } } return this.UTF8ToUTF16(res.join("")); } };使用:
先引入JS:
直接使用其中的方法:
Base64.decode(content);關(guān)于圖片的base64:
在圖片中直接將src設(shè)置為你的base64就可以實現(xiàn)解碼顯示了。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/99381.html
摘要:一編碼在聊圖片編碼之前,先來說說編碼,其實這一塊已經(jīng)有很多例子了。一次連接又是域名解析,開啟連接,發(fā)送請求,等待網(wǎng)絡(luò)延遲和服務(wù)器處理時間,下載資源較小是幾個意思 一、Base64編碼 在聊圖片編碼之前,先來說說Base64編碼,其實這一塊已經(jīng)有很多例子了。 Base64編碼么,其實就是一個招待好6爺,伺候好8爺?shù)倪^程 Base64是把字符串轉(zhuǎn)為二進(jìn)制,然后末尾補(bǔ)零,使總長度能除盡24...
摘要:當(dāng)然,也可自己寫一個轉(zhuǎn)換函數(shù),按照一定規(guī)則便行為編碼的字節(jié),如下例中國結(jié)果中國結(jié)果結(jié)果通過簡單的函數(shù),就可以完成編碼到編碼的轉(zhuǎn)換,進(jìn)而完成寬字節(jié)字符到編碼的轉(zhuǎn)換。 前端開發(fā)過程中會接觸各種各樣的編碼,比較常見的主要是 UTF-8 和 HTML 實體編碼,但是 web 前端的世界卻不止這兩種編碼,而且編碼的選擇也會造成一定的問題,如前后端開發(fā)過程中不同編碼的兼容、多字節(jié)編碼可能會造成的 ...
摘要:當(dāng)后端將數(shù)據(jù)取出再傳給前端時,發(fā)生了編碼混亂的問題。這樣的編碼錯誤問題導(dǎo)致數(shù)據(jù)上的,會造成不良的用戶體驗。但是,不幸的是,各方對該編碼的規(guī)則是不同的,這也造成亂碼的隱患。 本文由作者朱臻授權(quán)網(wǎng)易云社區(qū)發(fā)布。 1問題案例 曾在開發(fā)過程中,我們遇到了BASE64編碼亂碼的問題,該問題的場景如下: 當(dāng)web前端,將帶有中文字符的字符串base64編碼后,傳到后端。當(dāng)后端將數(shù)據(jù)取出再傳給we...
摘要:注意點如果所示,上面說到的編碼解碼方法并不支持中文,因為它們只支持編碼。轉(zhuǎn)換編碼中文進(jìn)行轉(zhuǎn)碼之后在編碼。最優(yōu)方案在某些情況下,用了上面的方法也會出現(xiàn)中文亂碼的情況,如獲取到的音樂歌詞解析出來的歌詞等。 為什么要編碼 簡單粗暴的解釋就是為了數(shù)據(jù)的安全性。 編碼/解碼常用方法(僅針對Base64) 編碼 我們一般使用 window.btoa() 對原始數(shù)據(jù)進(jìn)行編碼。 解碼 我們一般使用 w...
閱讀 2917·2021-11-24 09:39
閱讀 1175·2021-11-02 14:38
閱讀 4170·2021-09-10 11:26
閱讀 2760·2021-08-25 09:40
閱讀 2318·2019-08-30 15:54
閱讀 489·2019-08-30 10:56
閱讀 2756·2019-08-26 12:14
閱讀 3226·2019-08-26 12:13