- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法使用 Crypto-JS 成功加密二进制消息。我的数据位于数组缓冲区中。我正在 Angular 工作,并且进行了一个简短的测试,效果很好。我正在与 WiFi 设备通信。以下测试工作正常,使用简单的字符串,这证明加密和传输都正常工作。
var iv_hexString = this.buf2hex([146, 66, 191, 151, 23, 3, 113, 119, 231, 131, 133, 112, 79, 32, 114, 136]);
var key_hexString = this.buf2hex([123, 217, 20, 11, 24, 26, 85, 45, 114, 184, 27, 162, 37, 115, 222, 209, 241, 24, 175, 144, 175, 53, 196, 29, 24, 23, 17, 218, 131, 226, 53, 209]);
var key = CryptoJS.enc.Hex.parse(key_hexString);
var iv = CryptoJS.enc.Hex.parse(iv_hexString);
console.log('iv = ' + iv);
console.log('key = ' + key);
let cli_verify = CryptoJS.AES.encrypt("1111222233334444555566667777888899990000aaaabbbbccccddddeeeeffff", key, {
mode: CryptoJS.mode.CTR,
iv: iv,
padding: CryptoJS.pad.NoPadding
});
console.log('Cipher Text = ', cli_verify.ciphertext.toString());
// Test by decoding some shit here.
var decrypted = CryptoJS.AES.decrypt(cli_verify, key, {
mode: CryptoJS.mode.CTR,
iv: iv,
padding: CryptoJS.pad.NoPadding
});
console.log('Decrypted Output = ', decrypted.toString(CryptoJS.enc.Utf8));
这工作正常:
[ng] [console.log]: "iv = 9242bf9717037177e78385704f207288"
[ng] [console.log]: "key = 7bd9140b181a552d72b81ba22573ded1f118af90af35c41d181711da83e235d1"
[ng] [console.log]: "Cipher Text = " "de3cfe57c4d6fc5a8218b9eb801ebd49d3bd6cbf9ecd1b62656be424c09ba1d72b8ea3b6f304752b514ff4dc086a63a5349534e08e110f4855108a8d96804af3"
[ng] [console.log]: "Decrypted Output = " "1111222233334444555566667777888899990000aaaabbbbccccddddeeeeffff"
问题是我的数据不在字符串中。它是二进制的,因此很难作为字符串传输。我对另一端的代码没有任何控制权,它需要这种格式。我的数据可能包含 256 个代码中的任意一个:
let myMessage = new Uint8Array([0x0a, 0x11, 0x00, 0xff, 0x30, 0x53, 0x22, 0x6a, 0x8f, 0x05, 0x16, 0x15, 0x88, 0xb5]);
任何人都可以建议我如何格式化它,以便它能够被 crypto-js 接受。对于代码 0x30,这当然是“0”。出色的。这很适合串起来。 0x11 和 0x00:不太好!我尝试过以下方法:
var devPublic_hexString = this.buf2hex(this.device_Public_Key);
let cli_verify = CryptoJS.AES.encrypt(this.hex2a(devPublic_hexString), key, {
mode: CryptoJS.mode.CTR,
iv: iv,
padding: CryptoJS.pad.NoPadding
});
hex2a(hexx) {
var hex = hexx.toString();//force conversion
var str = '';
//for (var i = 0; (i < hex.length && hex.substr(i, 2) !== '00'); i += 2)
for (var i = 0; (i < hex.length); i += 2)
str += String.fromCharCode(parseInt(hex.substr(i, 2), 16));
return str;
}
仔细观察十六进制转储,有一些很好的线索:
5c fa 82 94 4e 79 64 08 9c 0b 9a 4d d8 8f 06 c5 39广告 c0 91 9b c7 cc 6a 0a 86 81 dd 5d ad 0b 03
5c c3 ba c2 82 c2 94 4e 79 64 08 c2 9c 0b c2 9a 4d c3 98 c2 8f 06 c3 85 39 c2 ad c3 80 c2 91 c2
等等。我厌倦了将匹配的位加粗,但你可以看到模式。问题是 c2 和 c3 代码都是关于什么的?为什么 0xfa 与 oxba 混淆? 0x98 和 0xd8 一样吗? 0xc5 & 0x85...以及 0xC0 & 0x80...是否与使用解码错误的非法字符串字符有关?我如何使用这个库来获取我的二进制数据?
最佳答案
您的问题源于以下事实:crypto-js
中的 WordArray
会将输入处理为 UTF-8 字符串,并且会发生代码点转换。您需要使用单字节编码,例如 Latin-1。以下是如何在一些表示形式之间进行转换:
const arrayToString = arr => arr.reduce((str, code) => str + String.fromCharCode(code), '');
const original = new Uint8Array([0x0a, 0x11, 0x00, 0xff, 0x30, 0x53, 0x22, 0x6a, 0x8f, 0x05, 0x16, 0x15, 0x88, 0xb5]);
const originalString = arrayToString(original);
// -> Hex 0a1100ff3053226a8f05161588b5
const encrypted = CryptoJS.AES.encrypt(CryptoJS.enc.Latin1.parse(originalString), 'secret');
const encryptedArray32 = Uint32Array.from(encrypted.ciphertext.words);
const encryptedArray8 = new Uint8Array(encryptedArray32.buffer);
// -> Hex f6b58e23281ed5323e80d22e6fb94752
const decryptedString = CryptoJS.AES.decrypt(encrypted, 'secret').toString(CryptoJS.enc.Latin1);
const decryptedArray8 = Uint8Array.from(Buffer.from(decryptedString, 'latin1'));
// -> Hex 0a1100ff3053226a8f05161588b5
关于javascript - 加密/解密二进制数据 crypto-js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59528472/
我有一个 C# 应用程序调用 Java 网络服务来验证用户密码。我想让 C# 应用程序加密密码,然后让 Java Web 服务解密密码。我已经完成了 Java 端的代码(解密代码),但我无法找出 C#
我正在使用以下代码在使用 openssl 的 Windows 中使用 C 加密和解密二进制数据。如您所见,在这两个函数中,我都知道纯文本的大小。有什么方法可以在不知道纯文本大小的情况下解密消息? #i
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我有一个非常恼人的问题,Java中使用RSA算法对字符串进行不可靠的加密和解密。它似乎只能在大约 35% 的时间内工作,而且我不明白为什么它有时能工作,有时却不能。这是我写的一些测试代码,试图验证加密
我已经设法编写了用于文件加密/解密的函数。但它非常慢,尤其是随着文件大小的增加。例如几MB长的音频/视频文件 我几乎浏览了所有帖子来改进它,并尝试更改算法。如果有任何更改可以帮助我提高性能,请帮助我。
我正在尝试让我的转置密码发挥作用。 每当我将加密方法得到的密文输入解密方法时,我应该得到原始的明文......但事实并非如此...... 我做错了什么? 感谢您的帮助! public String E
我正在使用密码来加密和解密消息: public String encrypt(String string) throws InvalidKeyException, IllegalBlockSizeEx
我有一个在 MySQL 中存储数据的 spring-mvc 堆栈。其中一些数据需要保护,所以我想我应该加密它。由于我以后可能需要使用这些数据(信用卡、SSN 等),所以我需要对其进行解密。我认为这排除
作为一名SEOER,都想了解百度算法,通过算法原理来找到捷径的优化方案,那么今天我把研究多年的百度算法原理解密给大家,可能不是最好的,但是我可以给大家保证,这些都是非常实际的。希望给SEOER带来一
我试图找到一种技术来加密和解密程序中的文件,而无需将密码硬编码到程序中,也无需向用户询问密码。 如果我也可以从我正在编写的另一个程序中解密文件,那就太好了。 到目前为止,我还没有多少运气找到一种看起来
有没有一种方法可以使用作为字符串参数传递给程序的私钥而不是使用存储在机器上的证书来解密 PowerShell 中的 RSA?欢迎任何帮助,我的代码如下。 Function Decrypt-Asymme
通过问题Is it possible to use the Grails Jasypt plugin outside the GORM layer for simple String encrypti
我需要解密/加密我的域类中的几列,并且正在寻找有关如何做的信息。我已经找到了jasypt加密插件,但不幸的是它似乎与Grails 2.4不兼容。 我可能可以将一些东西拼凑在一起,但是想要确保Im遵循最
我需要有关声音文件加密/解密的帮助。我想在存储这个声音文件时加密一个声音文件,并在播放这个文件时解密它。我阅读了有关 java 中的加密/解密以及 java 中可用于此的大量示例代码。但这些程序不适用
我很感兴趣是否可以使用 Excel Visual Basic 和某些加密服务提供程序进行字符串加密/解密。 我找到了一个演练 Encrypting and Decrypting Strings in
我们正在使用加密/解密和UIIMAGE。如果我们在不保存到iphone画廊的情况下进行加密和解密以及UIIMAge,则可以正常工作,但是,如果我们进行加密,保存到画廊,将(加密的图像)加载到应用程序中
我正在做一个像这样的简单程序: package rsaexample; import java.io.*; import java.math.BigInteger; import java.secur
我发现这段代码返回给定字符串的校验和。 public static String getChecksum(String md5) { int counter = 0; while (c
我在 Java SE 和 Android 项目上使用相同的代码。在 Java 和 Android 中运行的应用程序连接到相同的 MQTT 代理并交换消息。消息使用 AES 进行加密/解密。我对 Jav
我想在 openssl/libcrypto 中使用 RSA 加密/解密一个长文件(我知道 AES 更好,但这只是为了比较)。我将输入文件分成大小为 numBlocks = inputFileLengt
我是一名优秀的程序员,十分优秀!