0

0

如何实现Java中的简单加密算法_位运算异或加密实战

P粉602998670

P粉602998670

发布时间:2026-03-05 12:57:20

|

224人浏览过

|

来源于php中文网

原创

异或加密在java中“看起来能用”但实际不安全,因其仅为可逆位运算、无密钥派生和抗频率分析能力,安全性不如古典密码;仅适用于调试隐藏日志token等非敏感场景。

如何实现java中的简单加密算法_位运算异或加密实战

为什么异或加密在Java里“看起来能用”但实际不安全

异或(^)本身不是加密算法,它只是可逆的位运算;用它做“加密”,本质是混淆,没有密钥派生、无抗频率分析能力,连古典密码的安全性都不如。真实项目中直接用 xorEncrypt() 处理敏感数据,等于把密码写在纸上贴显示器边——开发时省事,上线后出事。

但它确实适合:调试时临时隐藏日志里的 token、配置文件里掩码简单标识符、教学演示对称变换原理。

  • 密钥必须和明文等长才“理论安全”(即一次一密),但 Java 里没人真这么干——太重,且密钥分发又成新问题
  • 用固定字节(如 0x55)当密钥?所有 'a' 都变成同一个值,一猜就中
  • String 经过 getBytes() 编码可能因平台默认编码不同导致解密失败(比如 Windows vs Linux)

Java里怎么写一个能跑通的xor加解密函数

核心就两行:逐字节异或,再异或一次还原。关键在统一编码和密钥处理。

下面这个 xorCipher() 能跑通,也暴露了典型陷阱:

立即学习Java免费学习笔记(深入)”;

卡拉OK视频制作
卡拉OK视频制作

卡拉OK视频制作,在几分钟内制作出你的卡拉OK视频

下载
public static byte[] xorCipher(byte[] input, byte[] key) {
    byte[] output = new byte[input.length];
    for (int i = 0; i < input.length; i++) {
        output[i] = (byte) (input[i] ^ key[i % key.length]);
    }
    return output;
}
  • 输入必须是 byte[],别传 String 直接算——先用 "UTF-8" 明确编码:str.getBytes(StandardCharsets.UTF_8)
  • 密钥 key 推荐用 SecureRandom 生成,至少 16 字节;硬编码字符串(如 "mykey")要转成字节数组,且注意其 UTF-8 长度可能≠字符数
  • 加解密用同一段代码,传入密文+同样密钥,自动还原——这是异或的数学特性,不是设计巧思

遇到“解密乱码”大概率是这三个地方错了

不是算法崩了,是编码/类型/边界没对齐。

  • 加密用 str.getBytes(),解密却用 new String(bytes) 不指定编码 → 默认平台编码,中文直接变 ???
  • 把密文字节数组误当成 String 打印(例如 System.out.println(cipherBytes))→ 输出 [B@xxxxx,不是乱码,是对象地址
  • 密钥长度为 0(比如空字符串 "" 导致 key.length == 0)→ i % 0ArithmeticException,但错误信息里根本没提“密钥为空”

如果真要保护数据,请立刻停用纯xor并换掉

哪怕只是本地配置加密,也该切到 Cipher.getInstance("AES/GCM/NoPadding");JDK 8+ 原生支持,性能好,有认证加密(AEAD),密钥还能用 PBEKeySpec + 盐值派生。

异或唯一不可替代的场景,是嵌入式或极低资源环境里做快速翻转——而那种环境,Java 本就不该出现。

记住:能用 ^ 一秒钟写出的“加密”,往往要用三天排查生产环境的字符错位问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

930

2023.08.02

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6513

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

840

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1088

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

1845

2024.03.01

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

313

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

290

2025.06.11

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

33

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.6万人学习

Java 教程
Java 教程

共578课时 | 76.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号