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

开发者社区> 李大嘴吧> 正文

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)));
  }
 }
}


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

相关文章
C#和Javascript间互转的Xxtea加解密
很有意思的一件事情,当我想要找 Xxtea 加解密算法的时候,发现了前同事(likui318)的代码,不妨分享出来。此代码满足: 1:Xxtea支持中文; 2:支持 JS 和 C# 加解密之间的互转;   一:C#部分 class XXTEA2 {     public stat...
667 0
PHP、Python、JavaScript实现AES加密解密
PHP、Python、JavaScript实现AES加密解密
17 0
[Java 安全]加密算法
Base64编码 算法简述 定义 Base64内容传送编码是一种以任意8位字节序列组合的描述形式,这种形式不易被人直接识别。 Base64是一种很常见的编码规范,其作用是将二进制序列转换为人类可读的ASCII字符序列,常用在需用通过文本协议(比如HTTP和SMTP)来传输二进制数据的情况下。
978 0
RSACryptoServiceProvider加密解密签名验签和DESCryptoServiceProvider加解密
原文:RSACryptoServiceProvider加密解密签名验签和DESCryptoServiceProvider加解密 C#在using System.Security.Cryptography下有 DESCryptoServiceProvider RSACryptoServiceProvider  DESCryptoServiceProvider 是用于对称加密 RSACryptoServiceProvider是用于非对称加密  对称加密的意思:有一个密钥 相当于加密算法,加密用它来加密,解密也需要用到它。
771 0
android jar 加密
引用:http://www.cnblogs.com/sandyzhou/archive/2011/12/31/2308403.html 自从接触了android开发之后,感觉代码都容易给一些工具反编译,比如我自己常用的dex2jar+jdgui,还有其它一些等等,所以下面就介绍下自己在实际应用的解决方案吧。
645 0
+关注
72
文章
2
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载