java&javascript自定义加密数据传输代码示例
程序员文章站
2024-02-11 20:35:04
在开发应用过程中,客户端与服务端经常需要进行数据传输,涉及到重要隐私信息时,开发者自然会想到对其进行加密,即使传输过程中被“有心人”截取,也不会将信息泄露。对于加密算法,相...
在开发应用过程中,客户端与服务端经常需要进行数据传输,涉及到重要隐私信息时,开发者自然会想到对其进行加密,即使传输过程中被“有心人”截取,也不会将信息泄露。对于加密算法,相信不少开发者也有所耳闻,比如md5加密,base64加密,des加密,aes加密,rsa加密等等。。可利用亦或,并,且,等进行简单加密。
示例代码中使用的^运算key=0x01,可自定义自己的规则。定义自己的运算,保证可逆数据不丢失即可。key也可定义,动态key。
java代码
public static string myencode(string str) throws unsupportedencodingexception { byte[] strbytes = str.getbytes("utf-8"); byte[] newstrbyte = new byte[strbytes.length]; for (int i = 0; i < strbytes.length; i++) { newstrbyte[i] = (byte) (strbytes[i] ^ 0x01); } return new string(newstrbyte); } string encodestr = myencode("idmmna\"547''+) ')%\"a ^*((!vnsme"); system.out.println(encodestr);
javascript代码
获取utf-8的byte
function toutf8array(str) { var utf8 = []; for (var i=0; i < str.length; i++) { var charcode = str.charcodeat(i); if (charcode < 0x80) utf8.push(charcode); else if (charcode < 0x800) { utf8.push(0xc0 | (charcode >> 6), 0x80 | (charcode & 0x3f)); } else if (charcode < 0xd800 || charcode >= 0xe000) { utf8.push(0xe0 | (charcode >> 12), 0x80 | ((charcode>>6) & 0x3f), 0x80 | (charcode & 0x3f)); } // surrogate pair else { i++; // utf-16 encodes 0x10000-0x10ffff by // subtracting 0x10000 and splitting the // 20 bits of 0x0-0xfffff into two halves charcode = 0x10000 + (((charcode & 0x3ff)<<10) | (str.charcodeat(i) & 0x3ff)); utf8.push(0xf0 | (charcode >>18), 0x80 | ((charcode>>12) & 0x3f), 0x80 | ((charcode>>6) & 0x3f), 0x80 | (charcode & 0x3f)); } } return utf8; }
获取byte并进行^计算
bytes=stringtoasciibytearray(str); for (var i = 0; i < bytes.length; i++) { var newbyte = (bytes[i]^0x01); // newbyte = (newbyte^0x01); console.log(string.fromcharcode(newbyte)); encodestr += string.fromcharcode(newbyte); }; console.log(encodestr);
总结
以上就是本文关于java&javascript自定义加密数据传输代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:
如有不足之处,欢迎留言指出。
上一篇: 浅谈自定义注解在Spring中的应用