您好,登錄后才能下訂單哦!
昨天在群看到有人發了個文章叫《“短”化你的代碼》,思路非常不錯,采用unicode的零寬字符來實現字符隱藏,雖然有字符,可是你卻看不見它。
這篇文章詳細的介紹了這種方法的實現原理,最后還給出了一個生成工具。
當然,作者算了留了一個小小的練習給我們,因為他只用了兩個字符,導致轉換后的數據是原始數據的 8倍。
他給我們提供了4個零寬字符,我們就可以縮小至4倍。
好了,我們來看下代碼吧。
(function(window) { var rep = { // 替換用的數據,使用了4個零寬字符,數據量減少了一半。 '00': '\u200b', '01': '\u200c', '10': '\u200d', '11': '\uFEFF' }; function hide(str) { str = str.replace(/[^\x00-\xff]/g, function(a) { // 轉碼 Latin-1 編碼以外的字符。 return escape(a).replace('%', '\\'); }); str = str.replace(/[\s\S]/g, function(a) { // 處理二進制數據并且進行數據替換 a = a.charCodeAt().toString(2); a = a.length < 8 ? Array(9 - a.length).join('0') + a : a; return a.replace(/../g, function(a) { return rep[a]; }); }); return str; } var tpl = '("@code".replace(/.{4}/g,function(a){var rep={"\u200b":"00","\u200c":"01","\u200d":"10","\uFEFF":"11"};return String.fromCharCode(parseInt(a.replace(/./g, function(a) {return rep[a]}),2))}))'; window.hider = function(code, type) { var str = hide(code); // 生成零寬字符串 str = tpl.replace('@code', str); // 生成模版 if (type === 'eval') { str = 'eval' + str; } else { str = 'Function' + str + '()'; } return str; } })(window);
大家可以通過最簡單的代碼例子進行測試一下,看看效果如何,也可以進一步優化,或者寫成插件什么的,就當練習吧。。
雖然這個東西沒什么實際用處,不過有時候玩玩還是不錯的,可出面試題嚇唬新人哦。。
以上就是小編為大家整理的js 奇葩技巧之隱藏代碼,希望對大家有所幫助!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。