当前位置: 首页 > 编程笔记 >

java&javascript自定义加密数据传输代码示例

华季同
2023-03-14
本文向大家介绍java&javascript自定义加密数据传输代码示例,包括了java&javascript自定义加密数据传输代码示例的使用技巧和注意事项,需要的朋友参考一下

在开发应用过程中,客户端与服务端经常需要进行数据传输,涉及到重要隐私信息时,开发者自然会想到对其进行加密,即使传输过程中被“有心人”截取,也不会将信息泄露。对于加密算法,相信不少开发者也有所耳闻,比如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自定义加密数据传输代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:

Java探索之Thread+IO文件的加密解密代码实例

多模字符串匹配算法原理及Java实现代码

java算法实现红黑树完整代码示例

如有不足之处,欢迎留言指出。

 类似资料:
  • 本文向大家介绍Android数据传输中的参数加密代码示例,包括了Android数据传输中的参数加密代码示例的使用技巧和注意事项,需要的朋友参考一下 Android开发中,难免会遇到需要加解密一些数据内容存到本地文件、或者通过网络传输到其他服务器和设备的问题,但并不是使用了加密就绝对安全了,如果加密函数使用不正确,加密数据很容易受到逆向破解攻击。还有很多开发者没有意识到的加密算法的问题。 1、数据传

  • 默认我们的数据传输都是不经过加密的,要加密传输的话得用上HTTPS协议。easyopen在1.4.0版本开始提供了数据加密传输,不需要HTTPS协议。 easyopen基于公私钥+AES加密传输,交互流程如下: 0. 事先把公钥放在客户端,私钥放在服务端 1. 客户端生成一个随机码randomKey 2. 将randomKey通过公钥RSA加密str = rsa_encode(randomKey,

  • 本文向大家介绍Android 自定义密码输入框实现代码,包括了Android 自定义密码输入框实现代码的使用技巧和注意事项,需要的朋友参考一下 效果 自定义密码输入框,项目的一个界面需求,我把这个自定义的输入框提取出来作为这次内容的题目。 输入前:   输入后:   输入1个字符就红一个圈圈,很简单的效果。 思路 1.自定义EditText。 2.背景为一个外圆环加内实心圆。 3.edittext

  • 本文向大家介绍SpringBoot Shiro配置自定义密码加密器代码实例,包括了SpringBoot Shiro配置自定义密码加密器代码实例的使用技巧和注意事项,需要的朋友参考一下 shiro主要有三大功能模块: 1. Subject:主体,一般指用户。 2. SecurityManager:安全管理器,管理所有Subject,可以配合内部安全组件。(类似于SpringMVC中的Dispatch

  • 自定义传输 Nest provides TCP and Redis as a built-in transport methods. It makes prototyping incredibly fast & easy, but sometimes you might want to use another type of transport, e.g. RabbitMQ messaging.

  • EasySwoole支持自定义添加一个socket资源参与系统底层的事件调度循环,添加事件循环与swoole原生的EventLoop一致,这里只做简单介绍,扩展应用请参照swoole文档 // 函数原型 bool swoole_event_add(int $sock, mixed $read_callback, mixed $write_callback = null, int $flags =