Java初学者异或加密解密教程
时间:2026-03-06 12:02:35 337浏览 收藏
本文深入浅出地讲解了如何用Java实现一个轻量、可复用的异或加解密工具,紧扣初学者易踩的坑——从异或运算“a^b^b==a”这一核心原理出发,强调其仅适用于教学演示、配置混淆等非安全场景;重点剖析了编码不一致、空密钥、char误用、字节/字符串转换失真等高频错误,并给出健壮的byte[]级实现方案与UTF-8编码统一实践指南,直击“中文变问号”等痛点本质,同时坦诚指出该方案无密钥派生、无完整性保护等根本性缺陷,划清安全红线:绝不可用于真实敏感数据,真正帮新手绕过字符编码陷阱,夯实底层字节操作认知。

为什么异或(^)能当加密用?
因为 a ^ b ^ b == a,两次异或同一个密钥就还原——这是它做简单加解密的唯一前提。不是“安全算法”,只是位运算的数学特性。适合教学、配置项混淆、临时掩码这类不涉及真实敏感数据的场景。
常见错误现象:String.getBytes() 编码不一致导致解密乱码;用 char 当密钥却没转成 int,结果只取低8位;对空字符串或 null 直接操作抛 NullPointerException。
- 密钥必须是
byte或能明确映射为byte的值(比如"key".getBytes(StandardCharsets.UTF_8)) - 不要用
new String(byte[])直接构造结果,务必指定编码,例如new String(decryptedBytes, StandardCharsets.UTF_8) - 异或不改变字节数组长度,所以加密后长度 = 原文长度,别指望它压缩或扩增数据
Java里怎么写一个可复用的异或加解密方法?
核心就是遍历字节数组,逐字节跟密钥字节异或。密钥短于原文时得循环复用——这是最容易写错的地方:有人用 i % key.length 却忘了 key.length == 0 会抛异常。
public static byte[] xorEncryptDecrypt(byte[] data, byte[] key) {
if (data == null || key == null || key.length == 0) {
throw new IllegalArgumentException("data and non-empty key required");
}
byte[] result = new byte[data.length];
for (int i = 0; i
- 输入输出都是
byte[],避免在String和byte[]之间无意识转换丢失信息 - 密钥建议用
StandardCharsets.UTF_8编码,别依赖平台默认编码 - 如果密钥是单字符(比如
'x'),记得先转成byte:(byte) 'x',而不是直接传char
实际调用时怎么避免中文变问号或乱码?
根本原因不是异或,是字符串和字节之间的编码没对齐。比如用 GBK 编码的字符串,却用 UTF_8 解回去,必然出错。
- 统一用
StandardCharsets.UTF_8处理所有String ↔ byte[]转换 - 测试时优先用英文+数字组合,确认逻辑正确后再加中文
- 打印调试时别只看
new String(bytes)输出,用Arrays.toString(bytes)看原始字节是否对称(加密前后字节序列应满足异或关系)
这个方案有什么硬伤?哪些地方不能碰?
它连“玩具级加密”都算勉强——没有密钥派生、无随机盐、无完整性校验。一旦密钥泄露或被猜中,所有数据瞬间裸奔。
- 绝不能用于密码、token、用户身份证号等真实敏感字段
- 别把密钥写死在代码里(比如
new byte[]{0x1a, 0x2b}),至少从配置文件或环境变量读 - 如果需要多端互通,确保所有端都用同一套编码和密钥字节序列,Java 的
"abc".getBytes()在 Windows 和 Linux 下默认编码可能不同
真正卡住人的往往不是异或本身,而是字节和字符那层薄薄的、但必须精确控制的转换边界。
终于介绍完啦!小伙伴们,这篇关于《Java初学者异或加密解密教程》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
225 收藏
-
206 收藏
-
148 收藏
-
198 收藏
-
348 收藏
-
428 收藏
-
385 收藏
-
338 收藏
-
495 收藏
-
447 收藏
-
105 收藏
-
474 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习