gpt4 book ai didi

java - 两个明文字符串的异或解密

转载 作者:太空宇宙 更新时间:2023-11-04 12:11:43 25 4
gpt4 key购买 nike

我被分配在我的 AP Java 类(class)中解密以下内容:umzDlBF8aFix

使用以下键:oE2dpffzEiFD

唯一的问题是我不知道如何进行异或来解密这些。我已经将它们转换成二进制:

键:101000|000100|110110|011101|101001|011111|110011|000100|100010|000101|000011

密文:110110|100110|110011|100101|000001|111100|011010|000101|100011|110001

但我不知道该怎么办。如果你能帮我解决这个问题,那就太好了!代码也很好,但不是必需的。

感谢一百万!

最佳答案

正如其他人所指出的,“异或”是一种奇妙的加密机制,因为加密和解密是完全相同的操作。如果 key 的每个部分只使用一次,那么您就拥有了最安全的加密算法。

如果您重复使用 key 的任何部分,它就会变成最糟糕的加密机制之一,因为这很容易被破解。

这里遇到的问题是 - 如何从字符转换为要加密的值。您可以采用 Unicode 字符值,但您的密文和 key 会得到虚假结果。按原样使用 Unicode 的问题还在于,在加密/解密后您可能会得到无法打印的字符,这通常不是问题,但在教科书示例中很难打印无法打印的字符。

为了解密您的文本,我假设字符的翻译是这样的。

  • A - Z => 0 - 25
  • a - z => 26 - 51
  • 0 - 9 => 52 - 61

(我不需要猜测 62/63 是什么,但空间和点是很好的猜测)。

使用该假设和异或,我获取您的密文 umzDlBF8aFix 和 key oE2dpffzEiFD,并最终得到明文 GiFeMeaPenny

由于这是可读的英语 - “给我一分钱” - 看起来上面的假设是合理的。

关于java - 两个明文字符串的异或解密,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39802054/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com