静态网页的加密思路
3006 点击·0 回帖
![]() | ![]() | |
![]() | 思路: 加密时:先把用户的密钥A用md5加密为B,然后用B异或源文件S0得到目标文件S1,把S1存入js变量中 解密时:询问密钥,然后操作同加密 因为用了md5,个人认为没有密钥的时候是无法破解的(暴力除外) 请运行代码查看效果: 代码实例: <html> <head> <title>web Encoder</title> <style> body { font-size:12px; line-height:12px; background-Color:buttonface; border-width:0px; overflow:auto; margin:0px; padding:4px; } #t1, #t2 { width:100%; height:40%; border-width:1px; overflow:auto; height:expression((document.body.clientHeight-100)/2); } input { border-width:1px; padding-left:10px; padding-right:10px; margin:4px; } </style> <script> function webEncode(){ strSource=escape(XOR(t1.value,STR.md5(p1.value))); //strSource=t1.value; strOut="<script> strHTML=""; "; for(var i=0;i+70<strSource.length;i+=70){ strOut+="strHTML+=""+addSlash(strSource.substring(i,i+70))+""; "; } strOut+="strHTML+=""+addSlash(strSource.substring(i,strSource.length))+""; "; strOut+=XOR+" "; //below code load the STR object strOut+="var STR = { hexcase : 0, /* hex output format. 0 - lowercase; 1 - "; strOut+="uppercase */ b64pad : "", /* base-64 pad character. "=" for "; strOut+="strict RFC compliance */ chrsz : 8, /* bits per input character"; strOut+=". 8 - ASCII; 16 - Unicode */ b64_hmac_md5: function(key, "; strOut+="data) { return binl2b64(core_hmac_md5(key, data)); }, b64_md5: "; strOut+=" function(s){ return binl2b64(core_md5(str2binl(s), s.length * this.c"; strOut+="hrsz));}, binl2b64: function(binarray){ var tab = "ABCDE"; strOut+="FGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; var"; strOut+=" str = ""; for(var i = 0; i < binarray.length * 4; i += 3) {"; strOut+=" var triplet = (((binarray[i >> 2] >> 8 * ( i %4)) ; 0xFF) "; strOut+="<< 16) | (((binarray[i+1 >> 2] >> 8 * ((i+1)%4)) ; "; strOut+="0xFF) << 8 ) | ((binarray[i+2 >> 2] >> 8 * ((i+2)%"; strOut+="4)) ; 0xFF); for(var j = 0; j < 4; j++) { if(i "; strOut+="* 8 + j * 6 > binarray.length * 32) str += this.b64pad; else "; strOut+="str += tab.charAt((triplet >> 6*(3-j)) ; 0x3F); } } r"; strOut+="eturn str; }, binl2hex: function(binarray){ var hex_t"; strOut+="ab = this.hexcase ? "0123456789ABCDEF" : "0123456789abcdef"; var "; strOut+="str = ""; for(var i = 0; i < binarray.length * 4; i++) { "; strOut+=" str += hex_tab.charAt((binarray[i>>2] >> ((i%4)*8+4)) ; 0xF) + "; strOut+=" hex_tab.charAt((binarray[i>>2] >> ((i%4)*8 )) ; 0xF); "; strOut+=" } return str; }, binl2str: function(bin){ var st"; strOut+="r = ""; var mask = (1 << this.chrsz) - 1; for(var i = 0; i <"; strOut+=" bin.length * 32; i += this.chrsz) str += String.fromCharCode(("; strOut+="bin[i>>5] >>> (i % 32)) ; mask); return str; }, bit_rol:"; strOut+=" function(num, cnt){return (num << cnt) | (num >>> (32 - cnt));}, "; strOut+=" core_hmac_md5: function(key, data){ var bkey = str2binl(k"; strOut+="ey); if(bkey.length > 16) bkey = core_md5(bkey, key.length * this"; strOut+=".chrsz); var ipad = Array(16), opad = Array(16); for(var"; strOut+=" i = 0; i < 16; i++) { ipad = bkey ^ 0x36363636; "; strOut+=" opad = bkey ^ 0x5C5C5C5C; } var hash = core_md"; strOut+="5(ipad.concat(str2binl(data)), 512 + data.length * this.chrsz); r"; strOut+="eturn core_md5(opad.concat(hash), 512 + 128); }, core_md5: "; strOut+=" function(x, len){ /* append padding */ x[len >> 5] |= 0x80 "; strOut+="<< ((len) % 32); x[(((len + 64) >>> 9) << 4) + 14] = len; "; strOut+=" var a = 1732584193; var b = -271733879; var c = -17325841"; strOut+="94; var d = 271733878; for(var i = 0; i < x.length; i +"; strOut+="= 16) { var olda = a; var oldb = b; var oldc"; strOut+=" = c; var oldd = d; a = this.md5_ff(a, b, c, d, x[i+"; strOut+=" 0], 7 , -680876936); d = this.md5_ff(d, a, b, c, x[i+ 1], 12, "; strOut+="-389564586); c = this.md5_ff(c, d, a, b, x[i+ 2], 17, 60610581"; strOut+="9); b = this.md5_ff(b, c, d, a, x[i+ 3], 22, -1044525330); "; strOut+=" a = this.md5_ff(a, b, c, d, x[i+ 4], 7 , -176418897); d = th"; strOut+="is.md5_ff(d, a, b, c, x[i+ 5], 12, 1200080426); c = this.md5_f"; strOut+="f(c, d, a, b, x[i+ 6], 17, -1473231341); b = this.md5_ff(b, c, "; strOut+="d, a, x[i+ 7], 22, -45705983); a = this.md5_ff(a, b, c, d, x[i+"; strOut+=" 8], 7 , 1770035416); d = this.md5_ff(d, a, b, c, x[i+ 9], 12,"; strOut+=" -1958414417); c = this.md5_ff(c, d, a, b, x[i+10], 17, -42063)"; strOut+="; b = this.md5_ff(b, c, d, a, x[i+11], 22, -1990404162); "; strOut+=" a = this.md5_ff(a, b, c, d, x[i+12], 7 , 1804603682); d = thi"; strOut+="s.md5_ff(d, a, b, c, x[i+13], 12, -40341101); c = this.md5_ff(c"; strOut+=", d, a, b, x[i+14], 17, -1502002290); b = this.md5_ff(b, c, d, "; strOut+="a, x[i+15], 22, 1236535329); a = this.md5_gg(a, b, c, d, x"; strOut+="[i+ 1], 5 , -165796510); d = this.md5_gg(d, a, b, c, x[i+ 6], 9"; strOut+=" , -1069501632); c = this.md5_gg(c, d, a, b, x[i+11], 14, 6437"; strOut+="17713); b = this.md5_gg(b, c, d, a, x[i+ 0], 20, -373897302); "; strOut+=" a = this.md5_gg(a, b, c, d, x[i+ 5], 5 , -701558691); d ="; strOut+=" this.md5_gg(d, a, b, c, x[i+10], 9 , 38016083); c = this.md5_"; strOut+="gg(c, d, a, b, x[i+15], 14, -660478335); b = this.md5_gg(b, c, "; strOut+="d, a, x[i+ 4], 20, -405537848); a = this.md5_g | |
![]() | ![]() |