您的位置:首页 > 其它

RC4加密解密算法

2015-07-16 18:48 225 查看
RC4相对是速度快、安全性高的加密算法。在实际应用中,我们可以对安全系数要求高的文本进行多重加密,这样破解就有一定困难了。如下测试给出了先用RC4加密,然后再次用BASE64编码,这样双重锁定,保证数据信息安全(个人见解,不周之处请谅解!)。

package com.bao.tools.encryption;

import java.io.IOException;
import java.util.Scanner;

import org.junit.Test;

/**
* @title RC4加密解密算法
* @author Administrator
* @date 2015-7-16
*/
public class CRC4 {

/*
* 加密解密算法
*/
public static String setEncrypted(String value, String key) {
//声明256位数组
int[] iS = new int[256];
byte[] iK = new byte[256];
//赋值
for (int i = 0; i < 256; i++)
iS[i] = i;

int j = 1;

//检索位置
for (short i = 0; i < 256; i++) {
iK[i] = (byte) key.charAt((i % key.length()));
}

j = 0;

//替换位置
for (int i = 0; i < 255; i++) {
j = (j + iS[i] + iK[i]) % 256;
int temp = iS[i];
iS[i] = iS[j];
iS[j] = temp;
}

int i = 0;
j = 0;
char[] iInputChar = value.toCharArray();//字符转换
char[] iOutputChar = new char[iInputChar.length];//获得字符长度
for (short x = 0; x < iInputChar.length; x++) {
i = (i + 1) % 256;
j = (j + iS[i]) % 256;
int temp = iS[i];
iS[i] = iS[j];
iS[j] = temp;
int t = (iS[i] + (iS[j] % 256)) % 256;
int iY = iS[t];
char iCY = (char) iY;
iOutputChar[x] = (char) (iInputChar[x] ^ iCY);//做字符异或运算
}
return new String(iOutputChar);
}

/*
* 测试
*/
@Test
public void test() throws IOException {

Scanner scanner = new Scanner(System.in);

System.out.println("------------使用RC4和BASE64多重加密算法---------");
System.out.println("请输入RC4使用的加密值 (value):");
String inputStr = scanner.nextLine();
System.out.println("请输入RC4加密键(key):");
String key = scanner.nextLine();
String str = setEncrypted(inputStr, key);//使用RC4加密
str = CBase64.setEncrypted(str);//使用base64编码(CBase64加密类请看 <Java中使用BASE64加密&解密>)

// 打印加密后的字符串
System.out.println("\n---------------------\n加密后字符:"+ str);

str = CBase64.getEncrypted(str);//首先使用CBase64解码
// 打印解密后的字符串
System.out.println("解密后字符 :"+ setEncrypted(str, key));

   scanner.close();
}
}

运行结果如下

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: