ArcFour加密解密,java RC4加密解密,java 加密解密-阿里云开发者社区

开发者社区> qq1413139134> 正文

ArcFour加密解密,java RC4加密解密,java 加密解密

简介:
+关注继续查看


package com.app.common.util;
public class ArcFour {
 /**
  * 加密解密 参数为String 字符串(String data, String key)
  * 
  * @param data
  * @param key
  * @return String
  * @throws UnsupportedEncodingException
  */
 public static final int vactorLen = 256;
 private static String encodeAndDecodeStr(String data, String key)
 {
  // 1.参数检查
  if (data != null && data.length() > 0 && key != null
    && key.length() > 0)
  {
   // 2. 初始化算法
   // 2.1定义矢量vactor
   int[] vactor = new int[vactorLen];
   // 2.2定义临时变量tempk
   byte[] tempK = new byte[vactorLen];
   // 2.3给vactor赋值ֵ0-255
   for (int i = 0; i < vactorLen; i++)
    vactor[i] = i;
   int j = 1;
   // 2.4循环给tempK赋值
   for (short i = 0; i < vactorLen; i++)
   {
    tempK[i] = (byte) key.charAt((i % key.length()));
   }
   j = 0;
   // 2.5 置换vactor值
   for (int i = 0; i < 255; i++)
   {
    j = (j + vactor[i] + tempK[i]) % vactorLen;
    int temp = vactor[i];
    vactor[i] = vactor[j];
    vactor[j] = temp;
   }
   int i = 0;
   j = 0;
   // 2.6把data定义成char[]数组dataChar
   char[] dataChar = data.toCharArray();
   // 2.7计算数组dataChar[]长度,用InputCharLen接收。
   int charLen = dataChar.length;
   // 2.8 定义 长度为InputCharLen的char数组iOutputChar[]
   char[] resultChar = new char[charLen];
   // 2.9 加密解密算法
   for (short x = 0; x < charLen; x++)
   {
    i = (i + 1) % vactorLen;
    j = (j + vactor[i]) % vactorLen;
    int temp = vactor[i];
    vactor[i] = vactor[j];
    vactor[j] = temp;
    char tempChar = (char) vactor[(vactor[i] + (vactor[j] % vactorLen))
      % vactorLen];
    resultChar[x] = (char) (dataChar[x] ^ tempChar);
   }
   // 3. 输出结果
   return new String(resultChar);
  }
  return null;
 }
 /**
  * 二进制转换16进制*********
  * 
  * @param buf
  * @return
  */
 private static String parseByte2HexStr(byte bytes[])
 {
  // 参数检查
  if (bytes != null && bytes.length > 0)
  {
   // 定义b长度为bLenth
   int bLenth = bytes.length;
   StringBuffer stringBuffer = new StringBuffer();
   for (int i = 0; i < bLenth; i++)
   {
    String hex = Integer.toHexString(bytes[i] & 0xFF);
    if (hex.length() == 1)
    {
     hex = '0' + hex;
    }
    stringBuffer.append(hex.toUpperCase());
   }
   return stringBuffer.toString();
  }
  return null;
 }
 // 测试**************
 public static void main(String[] args)
 {
  // String data = "梦想还是要有的,万一实现了呢?";
  String data = "s.,gKsf发$@($*@¥棥梦想hai¥##@……LSLK";
  String key = "abcdefa";
  // 原文
  System.out.println("加密前:" + data);
  // 密文
  String str = null;
  if (data != null && data.length() > 0)
  {
   str = encodeAndDecodeStr(data, key);
   System.out.println("加密后:" + parseByte2HexStr(str.getBytes()));
   // 解密
   System.out.println("解密后:"
     + new String(encodeAndDecodeStr(str, key)));
  }
 }
}


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
php在线加密的解密程序
 http://www.cha88.cn/safe/online_base64_decode.
745 0
Java使用AES加解密
Java使用AES加解密 目录 1.1生成密钥 1.2密钥的存储 1.3获取存储的密钥 1.4加解密 1.5使用存储的密钥进行加解密示例   AES是一种对称的加密算法,可基于相同的密钥进行加密和解密。
1115 0
C#和Javascript间互转的Xxtea加解密
很有意思的一件事情,当我想要找 Xxtea 加解密算法的时候,发现了前同事(likui318)的代码,不妨分享出来。此代码满足: 1:Xxtea支持中文; 2:支持 JS 和 C# 加解密之间的互转;   一:C#部分 class XXTEA2 {     public stat...
655 0
RSACryptoServiceProvider加密解密签名验签和DESCryptoServiceProvider加解密
原文:RSACryptoServiceProvider加密解密签名验签和DESCryptoServiceProvider加解密 C#在using System.Security.Cryptography下有 DESCryptoServiceProvider RSACryptoServiceProvider  DESCryptoServiceProvider 是用于对称加密 RSACryptoServiceProvider是用于非对称加密  对称加密的意思:有一个密钥 相当于加密算法,加密用它来加密,解密也需要用到它。
749 0
+关注
82
文章
1
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载