- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个 JAVA 程序,它向 asp 文件发出请求,并且工作正常。
现在我想加密POST请求,但我需要在JAVA和ASP上使用相同的加密 key 才能正确解密(或者这就是我的想法)。
如何从 vbscript 上的字符串生成 key ?我需要定制 IV 吗?我不知道那是什么:(
(我从未加密过任何东西,我对此很陌生)
set obj = server.CreateObject("System.Security.Cryptography.RijndaelManaged")
set utf = CreateObject("System.Text.UTF8Encoding")
s="This is a private message"
bytes=utf.GetBytes_4(s)
obj.GenerateKey() 'need to custom this
obj.GenerateIV() 'need to custom this?
set enc=obj.CreateEncryptor()
set dec=obj.CreateDecryptor()
bytec=enc.TransformFinalBlock((bytes),0,lenb(bytes))
sc=utf.GetString((bytec))
response.write sc
byted=dec.TransformFinalBlock((bytec),0,lenb(bytec))
sd=utf.GetString((byted))
response.write sd
最佳答案
经过几天的调查,我将发布我最终所做的事情。我知道这不是一个好的做法,我很快就会改变它,但现在还可以。
ASP 代码(解密 java 请求)
response.write desencriptar(encryptedStringHere)
Function desencriptar(str)
set obj= CreateObject("System.Security.Cryptography.RijndaelManaged")
set utf8 = CreateObject("System.Text.UTF8Encoding")
ekey = "16byteskeyhere" 'you'll need to change this
eiv = "16bytesIVhere" 'you'll need to change this
obj.BlockSize = 128
obj.Key = utf8.GetBytes_4(ekey)
obj.IV = utf8.GetBytes_4(eiv)
obj.Padding = 5
set decryptor=obj.CreateDecryptor()
desencriptado = Base64ToByte(str)
byted=decryptor.TransformFinalBlock((desencriptado),0,lenb(desencriptado))
desencriptado = utf8.getString((byted))
desencriptar = desencriptado
end function
Function Base64ToByte(ByVal vCode)
Dim oXML, oNode
Set oXML = CreateObject("Msxml2.DOMDocument.3.0")
Set oNode = oXML.CreateElement("base64")
oNode.dataType = "bin.base64"
oNode.text = vCode
Base64ToByte = oNode.nodeTypedValue
Set oNode = Nothing
Set oXML = Nothing
End Function
JAVA 代码(加密函数)
public static String aesEncrypt(String value, String key, String initVector) {
try {
IvParameterSpec iv = new IvParameterSpec(initVector.getBytes("UTF-8"));
SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "Rijndael");
Cipher cipher = Cipher.getInstance("Rijndael/CBC/PKCS5PADDING");
cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);
byte[] encrypted = cipher.doFinal(value.getBytes());
return Base64.getEncoder().encodeToString(encrypted);
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}
Docs: RijndaelManaged | PaddingMode | CipherMode
关于java - vbscript 上的 aes/rijndael 自定义 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45501620/
我使用函数 EncryptStringToBytes 将纯文本加密为字节数组,并且最后将字节数组转换为字符串并返回。 我使用另一个函数将加密文本解密为纯文本。 我尝试用 RC2 对文本进行打乱,但它引
我正在考虑切换到将 session 数据存储在加密的 cookie 中,而不是在我的服务器上的某个地方。虽然这将导致每个请求使用更多带宽 - 它将节省额外的数据库服务器负载和存储空间。 无论如何,我计
我在使用 BouncyCaSTLe API for Java 实现 Rijndael 加密时遇到问题。 当我执行cipher.doFinal(inputTextBytes, intOutOff);时,
我正在使用发现的 DCPcrypt 库 here . 这是一个加密字符串的小代码 InitializationVector: AnsiString; const Key: Ansistring = '
我正在尝试模仿 http://www.hanewin.net/encrypt/aes/aes-test.htm 的 Rijndael (AES) 加密在Python3. 具体来说,当我使用以下输入时:
我正在一个类中组织一些非常基本的对称加密/解密代码以供将来使用。我能够成功加密和解密...只是有一个小问题。 这是我从一个流中读入并加密/解密到另一个流的代码: public void Encrypt
我正在尝试使用 Rijndael 加密来加密图像文件,我一定是做错了什么,因为解密的文件在文件的前面带有额外的数据,最后可能还有一点额外的数据。我对这种加密算法还很陌生,所以我很确定我只是遗漏了一些简
我正在研究 AES-256-CBC 的实现(如下所示),这将用于客户端到数据库的设置。 key 存储在本地,此方案的目的是在数据库内容泄漏时使某些值不可读。 由于IV是固定长度的,所以我打算将密文设为
我正在尝试使用 Rijndael 或 Aes 以及下面的代码来加密/解密字符串。 public class Crypto { private const string defaultVecto
我想使用 C# 研究 Rijndael 算法。有人可以帮我解决这个问题吗? 最佳答案 我假设您指的是 Rijndael 加密算法 - 在这种情况下 RinjdaelManaged会有用的。 MSDN
您好,我正在尝试通过 Rijaendal 加密/解密字符串。我根本无法弄清楚为什么解密会失败。我总是以不正确的填充错误结束。让我失望的一件事是我作为 HEX 数组返回的加密结果。它的长度为 14 个字
我有一个进行 Rijndael 加密的 PHP 代码的引用。我想将它转换为java代码,我尝试了几个例子,但没有一个对我有用。这是 php 代码: $initialisationVector = ha
我多次使用以下 Rijndael 代码进行加密。但是为什么它不能加密一个 4.2 GB 的 ISO 文件呢?事实上,我的电脑有 16GB 内存,应该不是内存问题。我使用 Windows 7 旗舰版。代
只有部分字符串被解密,我认为这与我的编码有关。 这是发生了什么: string s = "The brown fox jumped over the green frog";
我尝试了来自SO和整个网络的许多答案,但仍然没有成功。 我使用以下tool进行加密。 text to encrypt: tom key: exo123exo1exo123 input (textfie
我有一个编码和解码字符串的安全类,但是当我尝试解码时 - 出现了问题。 这是我的安全类: class Security { public static String encrypt(Strin
我写的一些软件使用了.Net4.0的Rijndael算法来加密和解密许可证信息。 问题如下:该程序生成一个字符串,该字符串被转换为 byte[]。这个 byte[] 然后用 Rijndael 加密成另
我在一个网站上找到了这段代码 private void EncryptFile(string inputFile) { string password
当我选择密码加密时,我发现Rijndael算法是最好的加密之一,无法通过暴力破解。 所以我选择了Rijndael算法对用户密码进行加密。 现在我已经确定,哈希(不可逆)比加密(可逆)更安全[如果我错了
我有一些代码可以用 Rijndael 解密密码 public static string DecryptPassword(string encrypted) { using (MemorySt
我是一名优秀的程序员,十分优秀!