Java RC4加密算法

一、RC4加密算法

在密码学中,RC4(来自Rivest Cipher 4的缩写)是一种流加密算法,密钥长度可变。它加解密使用相同的密钥,因此也属于对称加密算法。

百度百科 - RC4:https://baike.baidu.com/item/RC4/3454548?fr=ge_ala

二、Rc4Utils工具类

1、方式一

下面 Rc4Utils 提供了针对文本内容、字节数组内容的加解密实现。使用加密算法实现。

import org.apache.commons.codec.binary.Base64;import java.nio.charset.StandardCharsets;
import java.util.Arrays;public class Rc4Utils {/*** 对文本内容进行加密.** @param plainText 待加密明文内容.* @param rc4Key    RC4密钥.* @return 加密的密文.*/public static String encodeText(String plainText, String rc4Key) {byte[] plainBytes = plainText.getBytes(StandardCharsets.UTF_8);byte[] cipherBytes = rc4EnOrDecode(plainBytes, rc4Key);return Base64.encodeBase64String(cipherBytes);}/*** 对文本密文进行解密.** @param cipherText 待解密密文.* @param rc4Key     RC4密钥.* @return 解密的明文.*/public static String decodeText(String cipherText, String rc4Key) {byte[] cipherBytes = Base64.decodeBase64(cipherText);byte[] plainBytes = rc4EnOrDecode(cipherBytes, rc4Key);return new String(plainBytes, StandardCharsets.UTF_8);}/*** 对字节数组内容进行加密.** @param plainBytes 待加密明文内容.* @param rc4Key     RC4密钥.* @return 加密的密文.*/public static byte[] encodeBytes(byte[] plainBytes, String rc4Key) {byte[] cipherBytes = rc4EnOrDecode(plainBytes, rc4Key);return cipherBytes;}/*** 对字节数组密文进行解密.** @param cipherBytes 待解密密文.* @param rc4Key      RC4密钥.* @return 解密的明文.*/public static byte[] decodeBytes(byte[] cipherBytes, String rc4Key) {byte[] plainBytes = rc4EnOrDecode(cipherBytes, rc4Key);return plainBytes;}/*** 初始化RC4密钥.** @param rc4Key RC4密钥.* @return 初始化后的密钥.* @throws Exception 可能的异常.*/private static byte[] rc4InitKey(String rc4Key) {byte[] keyBytes = null;byte[] keyState = null;int indexFirst = 0;int indexSecond = 0;// 变量初始化.keyBytes = rc4Key.getBytes(StandardCharsets.UTF_8);keyState = new byte[256];for (int i = 0; i < 256; i++) {keyState[i] = (byte) i;}// 进行初始化.if (keyBytes == null || keyBytes.length == 0) {return null;}for (int i = 0; i < 256; i++) {indexSecond = ((keyBytes[indexFirst] & 0xff) + (keyState[i] & 0xff) + indexSecond) & 0xff;byte tmp = keyState[i];keyState[i] = keyState[indexSecond];keyState[indexSecond] = tmp;indexFirst = (indexFirst + 1) % keyBytes.length;}return keyState;}/*** RC4算法进行加解密.** @param bytes  待处理内容.* @param rc4Key RC4密钥.* @return 处理后结果内容.*/public static byte[] rc4EnOrDecode(byte[] bytes, String rc4Key) {int x = 0;int y = 0;byte key[] = rc4InitKey(rc4Key);int xorIndex;byte[] result = new byte[bytes.length];// 数据加密.for (int i = 0; i < bytes.length; i++) {x = (x + 1) & 0xff;y = ((key[x] & 0xff) + y) & 0xff;byte tmp = key[x];key[x] = key[y];key[y] = tmp;xorIndex = ((key[x] & 0xff) + (key[y] & 0xff)) & 0xff;result[i] = (byte) (bytes[i] ^ key[xorIndex]);}return result;}public static void main(String[] args) throws Exception {//String rc4Key = "1234567890";String rc4Key = "78077e1be9204c21ac03cda1e6ea7a01";String plainText = "This is 一段明文内容 123 !";String cipherText = null;// 文本加解密测试.System.out.println("----------------------- 文本加解密测试 -------------------------");System.out.println("明文:" + plainText);cipherText = Rc4Utils.encodeText(plainText, rc4Key);System.out.println("密文:" + cipherText);plainText = Rc4Utils.decodeText(cipherText, rc4Key);System.out.println("解密明文:" + plainText);System.out.println();System.out.println("----------------------- 字节数组加解密测试 -------------------------");byte[] plainBytes = plainText.getBytes("UTF-8");byte[] cipherBytes = null;System.out.println("明文:" + Arrays.toString(plainBytes));cipherBytes = Rc4Utils.encodeBytes(plainBytes, rc4Key);System.out.println("密文:" + Arrays.toString(cipherBytes));plainBytes = Rc4Utils.decodeBytes(cipherBytes, rc4Key);System.out.println("解密明文:" + Arrays.toString(plainBytes));System.out.println();}}

在这里插入图片描述

2、方式2

下面 Rc4Utils2 提供了针对文本内容的加解密实现。使用 Java封装好的类实现。

import lombok.extern.slf4j.Slf4j;import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;@Slf4j
public class Rc4Utils2 {/*** 对文本内容进行加密.** @param plainText 待加密明文内容.* @param rc4Key    RC4密钥.* @return 加密的密文.*/public static String encodeText(String plainText, String rc4Key) {String result = "";try {Cipher cipher = Cipher.getInstance("RC4");SecretKeySpec key = new SecretKeySpec(rc4Key.getBytes(StandardCharsets.UTF_8), "RC4");cipher.init(Cipher.DECRYPT_MODE, key);byte[] encryptedBytes = cipher.doFinal(plainText.getBytes(StandardCharsets.UTF_8));result = Base64.getEncoder().encodeToString(encryptedBytes);} catch (Throwable e) {log.error(" 加密 encodeText方法异常,e={}", e);e.printStackTrace();}return result;}/*** 对文本密文进行解密.** @param cipherText 待解密密文.* @param rc4Key     RC4密钥.* @return 解密的明文.*/public static String decodeText(String cipherText, String rc4Key) {String result = "";try {Cipher cipher = Cipher.getInstance("RC4");SecretKeySpec key = new SecretKeySpec(rc4Key.getBytes(StandardCharsets.UTF_8), "RC4");cipher.init(Cipher.DECRYPT_MODE, key);byte[] bytesA = Base64.getDecoder().decode(cipherText.getBytes(StandardCharsets.UTF_8));result = new String(cipher.update(bytesA), StandardCharsets.UTF_8);} catch (Throwable e) {log.error(" 解密 decodeText方法异常,e={}", e);e.printStackTrace();}return result;}public static void main(String[] args) {/*** rc4Key有长度限制* java.security.InvalidKeyException: Illegal key size or default parameters*///String rc4Key = "78077e1be9204c21ac03cda1e6ea7a01";String rc4Key = "1234567890";String plainText = "This is 一段明文内容 123 !";String cipherText = null;// 文本加解密测试.System.out.println("----------------------- 文本加解密测试 -------------------------");System.out.println("明文:" + plainText);cipherText = Rc4Utils2.encodeText(plainText, rc4Key);System.out.println("密文:" + cipherText);plainText = Rc4Utils2.decodeText(cipherText, rc4Key);System.out.println("解密明文:" + plainText);System.out.println();}}

在这里插入图片描述

参考文章:

  • RC4 加密算法:https://blog.51cto.com/u_15301988/3089450

– 求知若饥,虚心若愚。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/247618.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaEE 网络原理

JavaEE 网络原理 文章目录 JavaEE 网络原理1. 网络互连1.1 局域网LAN1.2 广域网WAN 2. 网络通信基础2.1 IP地址2.2 端口号 3. 网络协议3.1 概念3.2 五元组3.3 协议分层3.4 TCP/IP 五层模型3.5 封装和分用 1. 网络互连 随着时代的发展&#xff0c;需要多个计算机协同工作来完成…

Docker安装RcoketMQ

1、Docker安装RcoketMQ-4.9.4 在同级文件夹创建目录config&#xff0c;并在里面创建文件broker.conf&#xff0c;文件内容如下&#xff1a; brokerClusterNameDefaultCluster brokerNamebroker-a brokerId0 deleteWhen04 fileReservedTime48 brokerRoleASYNC_MASTER flushDis…

Java项目:基于SSM框架实现的高校毕业生就业管理系统(ssm+B/S架构+源码+数据库+毕业论文)

一、项目简介 本项目是一套ssm817基于SSM框架实现的高校毕业生就业管理系统&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者。 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调…

Qlik Sense : IntervalMatch(离散匹配)

什么是IntervalMatch IntervalMatch 前缀用于创建表格以便将离散数值与一个或多个数值间隔进行匹配&#xff0c;并且任选匹配一个或多个额外关键值。 语法&#xff1a; IntervalMatch (matchfield)(loadstatement | selectstatement ) IntervalMatch (matchfield,keyfield…

Docker部署Stable-Diffusion-webui

前排提示&#xff1a;如果不想折腾&#xff0c;可直接跳到最后获取封装好的容器&#xff0c;一键运行 :D 前言 乘上AI生成的快车&#xff0c;一同看看沿途的风景。 启一个miniconda容器 docker run -itd -v 宿主机内SD项目路径:/tmp --gpus all --ipc host -p 7860:7860 con…

正则匹配 | 正则实际应用探索分享

这并不是一篇教正则基础的文章&#xff0c;其正则式不能对您进行使用后的结果负责&#xff0c;请以研究的眼光看待本篇文章。 技术就是懒人为了更好的懒才会想办法搞的东西&#xff0c;我最近因为某些原因需要频繁删除注释 我就想到通过替换的正则功能快速删除文件中的简单注…

RT-Thread: STM32 SPI使用流程

1.添加驱动 ①点开设置界面 ②勾选看门 SPI 驱动 ③点击保存 ④查看添加的驱动文件 drv_spi.c 2.打开驱动头文件定义 ①打开配置文件 ②打开定义 3.打开需要开启的SPI总线 打开 drivers 目录下的 board.h 用SPI搜索&#xff0c;找到如下文字&#xff0c;打开对应的宏。 /*-…

上门服务小程序|预约上门服务系统开发有哪些功能?

在现代快节奏的生活中&#xff0c;压力和疲劳常常困扰着我们。为了缓解这种状况&#xff0c;越来越多的人选择去按摩店进行放松。然而&#xff0c;繁忙的工作和家庭责任往往让我们无法抽出时间去按摩店。在这种情况下&#xff0c;上门按摩服务应运而生。而随着科技的发展&#…

Niushop 开源商城 v5.1.7:支持PC、手机、小程序和APP多端电商的源码

Niushop 系统是一款基于 ThinkPHP6 开发的电商系统,提供了丰富的功能和完善的商品机制。该系统支持普通商品和虚拟商品,并且针对虚拟商品还提供了完善的核销机制。同时,它也支持新时代的商业模式,如拼团、分销和多门店砍价等营销活动。 配送方式方面,Niushop 系统支持物流…

JAVAEE初阶 网络编程(六)

TCP协议 一. 四次挥手二. 连接管理过程中TCP状态的变化2.1 listen状态2.2 established状态2.3 CLOSE_WAIT状态2.4 TIME_WAIT状态 三. 滑动窗口3.1 ack丢了3.2 数据丢了 一. 四次挥手 我们都知道&#xff0c;在三次握手中是可以把中间步骤合并成一个步骤执行&#xff0c;那么在四…

openGaussdb5.0单点企业版部署_Centos7_x86

本文档环境&#xff1a;CentOS7.9 x86_64 4G1C40G python2.7.5 交互式初始化环境方式 介绍 openGauss是一款开源关系型数据库管理系统&#xff0c;采用木兰宽松许可证v2发行。openGauss内核深度融合华为在数据库领域多年的经验&#xff0c;结合企业级场景需求&#xff0c;持续…

使用vscode查bug

具体操作 修改CMakeList.txt # set(CMAKE_BUILD_TYPE "Release")//注释Release模式 set(CMAKE_BUILD_TYPE "Debug")//设置为Debug模式 # set(CMAKE_CXX_FLAGS_RELEASE "-O3 -Wall -g")//注释*这行代码是用来设置 CMake 构建系统中 Release 模式…

我道歉!我被小米汽车举报了

文 | AUTO芯球 作者 | 雷歌 前几天&#xff0c;我写了《小米&#xff0c;不要将卖手机那套话术带进汽车圈》。 小米汽车向腾讯举报&#xff0c;谴责我对他们进行“品牌抹黑、虚构诋毁”&#xff01; 我要向小米道歉。 我不该说“16.8亿种驾驶模式是文字游戏”。那是你们的说…

[C++]c++判断CPU的类型及支持的指令集

1、利用cpui判断cpu的类型及支持的指令集&#xff0c;可以进行条件编程&#xff1a;&#xff08;InstructionSet.h&#xff09; #pragma once// InstructionSet.cpp // Compile by using: cl /EHsc /W4 InstructionSet.cpp // processor: x86, x64 // Uses the __cpuid intrin…

DolphinScheduler + Amazon EMR Serverless 的集成实践

01 背景 Apache DolphinScheduler 是一个分布式的可视化 DAG 工作流任务调度开源系统&#xff0c;具有简单易用、高可靠、高扩展性、⽀持丰富的使用场景、提供多租户模式等特性。适用于企业级场景&#xff0c;提供了一个可视化操作任务、工作流和全生命周期数据处理过程的解决方…

uniapp上传音频文件到服务器

视频教程地址&#xff1a; 【uniapp录音上传组件&#xff0c;将录音上传到django服务器】 https://www.bilibili.com/video/BV1wi4y1p7FL/?share_sourcecopy_web&vd_sourcee66c0e33402a09ca7ae1f0ed3d5ecf7c uniapp 录制音频文件上传到django服务器保存到服务器 &#xf…

群辉开启WebDav服务+cpolar内网穿透实现移动端ES文件浏览器远程访问本地NAS文件

文章目录 1. 安装启用WebDAV2. 安装cpolar3. 配置公网访问地址4. 公网测试连接5. 固定连接公网地址6. 使用固定地址测试连接 本文主要介绍如何在群辉中开启WebDav服务&#xff0c;并结合cpolar内网穿透工具生成的公网地址&#xff0c;通过移动客户端ES文件浏览器即可实现移动设…

msfconsole实战使用(结合靶场演示)

msfconsole实战使用 前言 MSFconsole&#xff08;Metasploit Framework Console&#xff09;是Metasploit框架的一部分&#xff0c;是一个功能强大的渗透测试工具。Metasploit框架是一个开源的安全工具&#xff0c;旨在开发、测试和执行针对计算机系统的攻击。MSFconsole是Me…

数据湖技术之发展现状篇

一. 大数据处理架构&#xff1a; 大数据处理架构的发展过程具体可以分为三个主要阶段&#xff1a;批处理架构、混合处理架构&#xff08;Lambda、Kappa架构&#xff09;、湖仓一体。首先是随着Hadoop生态相关技术的大量应用&#xff0c;批处理架构应运而生&#xff0c;借助离线…

ThinkPhp3.2(qidian)部署文档

宝塔环境部署 申请域名以及域名解析 具体配置&#xff0c;可百度之 在宝塔面板中创建网站 上传代码导入数据配置运行目录 注意&#xff1a;&#xff08;如果版本&#xff1a;thinkphp3.2 &#xff09;配置 运行目录要特别注意&#xff1a;运行目录要选择根目录“/”&#xff…