- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 netbeans 中构建一个桌面应用程序,以便在密码键盘(设备)上加载按键。相同的代码在 android 上运行并且使用 16 字节键可以正常工作但是在桌面应用程序上它会抛出 16 字节错误但是它可以正常使用 24 字节键,错误是:
java.security.InvalidKeyException: Wrong key size
at com.sun.crypto.provider.DESedeCrypt.init(DESedeCrypt.java:69)
at com.sun.crypto.provider.ElectronicCodeBook.init(ElectronicCodeBook.java:93)
at com.sun.crypto.provider.CipherCore.init(CipherCore.java:582)
at com.sun.crypto.provider.CipherCore.init(CipherCore.java:458)
at com.sun.crypto.provider.DESedeCipher.engineInit(DESedeCipher.java:166)
at javax.crypto.Cipher.implInit(Cipher.java:797)
at javax.crypto.Cipher.chooseProvider(Cipher.java:859)
at javax.crypto.Cipher.init(Cipher.java:1229)
at javax.crypto.Cipher.init(Cipher.java:1166)
at payokeygen.CryptoUtil.encrypt3DESECB(CryptoUtil.java:62)
at payokeygen.UseDatecs.loadKeys(UseDatecs.java:135)
at payokeygen.mainscreen.loadPPEKeysActionPerformed(mainscreen.java:435)
at payokeygen.mainscreen.access$300(mainscreen.java:34)
at payokeygen.mainscreen$4.actionPerformed(mainscreen.java:186)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2346)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
at java.awt.Component.processMouseEvent(Component.java:6527)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6292)
at java.awt.Container.processEvent(Container.java:2234)
at java.awt.Component.dispatchEventImpl(Component.java:4883)
at java.awt.Container.dispatchEventImpl(Container.java:2292)
at java.awt.Component.dispatchEvent(Component.java:4705)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4898)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4533)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4462)
at java.awt.Container.dispatchEventImpl(Container.java:2278)
at java.awt.Window.dispatchEventImpl(Window.java:2739)
at java.awt.Component.dispatchEvent(Component.java:4705)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:746)
at java.awt.EventQueue.access$400(EventQueue.java:97)
at java.awt.EventQueue$3.run(EventQueue.java:697)
at java.awt.EventQueue$3.run(EventQueue.java:691)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:86)
at java.awt.EventQueue$4.run(EventQueue.java:719)
at java.awt.EventQueue$4.run(EventQueue.java:717)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:716)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:201)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)
Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
at java.io.OutputStream.write(OutputStream.java:75)
at com.datecs.pinpad.Pinpad.cryptoExchangeECBKey(Pinpad.java:1362)
at payokeygen.UseDatecs.loadKeys(UseDatecs.java:135)
at payokeygen.mainscreen.loadPPEKeysActionPerformed(mainscreen.java:435)
at payokeygen.mainscreen.access$300(mainscreen.java:34)
at payokeygen.mainscreen$4.actionPerformed(mainscreen.java:186)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2346)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
at java.awt.Component.processMouseEvent(Component.java:6527)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6292)
at java.awt.Container.processEvent(Container.java:2234)
at java.awt.Component.dispatchEventImpl(Component.java:4883)
at java.awt.Container.dispatchEventImpl(Container.java:2292)
at java.awt.Component.dispatchEvent(Component.java:4705)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4898)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4533)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4462)
at java.awt.Container.dispatchEventImpl(Container.java:2278)
at java.awt.Window.dispatchEventImpl(Window.java:2739)
at java.awt.Component.dispatchEvent(Component.java:4705)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:746)
at java.awt.EventQueue.access$400(EventQueue.java:97)
at java.awt.EventQueue$3.run(EventQueue.java:697)
at java.awt.EventQueue$3.run(EventQueue.java:691)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:86)
at java.awt.EventQueue$4.run(EventQueue.java:719)
at java.awt.EventQueue$4.run(EventQueue.java:717)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:716)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:201)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)
在密码键盘上加载按键的代码是:
pinpad.cryptoExchangeECBKey(HMK_INDEX, KEK_PIN_INDEX, Pinpad.KEY_KEK_PIN, 0, CryptoUtil.encrypt3DESECB(HMK, KEK_PIN));
“CryptoUtil”中的 encrypt3DESECB 函数是:
public static byte[] encrypt3DESECB(byte[] keyBytes, byte[] dataBytes) {
try {
SecretKeySpec newKey = new SecretKeySpec(keyBytes, "DESede");
Cipher cipher = Cipher.getInstance("DESede/ECB/NoPadding");
cipher.init(Cipher.ENCRYPT_MODE, newKey);
System.out.println("function called");
return cipher.doFinal(dataBytes);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
16字节 key 是:1A C4 F2 34 79 CD 8F 23 0B C4 9D 2C 98 C8 91 EA
使用 JDK 1.8。请帮助,提前致谢!
最佳答案
在 3Des 的背后实际上只是 3 个 DES 操作,每个操作都需要一个 8 字节的 key 。这需要 24 个字节的 key Material ……但是一些实现支持 16 个字节的 key ,其中前 8 个字节在幕后“自动重复”……其他人可能不支持这个。然而,您可以通过重复前 8 个字节来自己完成此操作 - 如下所示:
public static byte[] encrypt3DESECB(byte[] keyBytes, byte[] dataBytes) {
try {
if (keyBytes.length == 16) { // short key ? .. extend to 24 byte key
byte[] tmpKey = new byte[24];
System.arraycopy(keyBytes, 0, tmpKey, 0, 16);
System.arraycopy(keyBytes, 0, tmpKey, 16, 8);
keyBytes = tmpKey;
}
SecretKeySpec newKey = new SecretKeySpec(keyBytes, "DESede");
...
...
关于java.security.InvalidKeyException : Wrong key size,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34737457/
我遇到的问题只有在我要生成签名的 apk 时才会发生,但是当我直接从 Android Studio 运行时,一切正常。 错误发生在这里: val key = keyStore? .getKey(KEY
我在尝试使用我的公钥加密时遇到了上述异常。 java.security.InvalidKeyException: IOException: DerInputStream.getLength(): le
我是 Java 新手,想使用 RSA 算法包装对称 key 。就我而言,我不会生成用于包装的公钥,而是从 Microsoft Keystore 检索公钥。 // Encrypt the generat
我已经能够使用该算法来加密和解密文件,但是当我尝试将文件从 Android 发送到 WAS 服务器时,它失败了。这是加密的一面 Security.addProvider(new BouncyC
我需要将加密的密码存储在数据库中而不存储任何 key 或盐。我想确保它也更安全,即使它是双向加密。所以在谷歌搜索了一下之后,我创建了一个示例程序来测试它。我的想法是创建一个自定义 JPA Attrib
我正在尝试在 android 上运行 netty。它在运行 3.2 的摩托罗拉 Xoom 平板电脑上运行良好。但它在分别运行 2.3.6 和 3.1 的 Samsung Galaxy S 和 Gala
亲爱的, 我需要帮助来理解为什么 decryptString 不起作用并抛出“java.security.InvalidKeyException:需要 RSA 私钥或公钥”。当调用加密方法时,我通过私
我目前正在开发一个使用 key 加密/解密特定文件的功能。我写了三个类,一个生成 key ,一个用 key 加密文件,一个解密。 生成 key 和加密文件工作正常,但是当我尝试解密文件时,在以下行抛出
我有一个测试在我的开发 MacBook Pro 上运行良好,但无法在持续集成 TeamCity 服务器中运行。 错误如下: java.security.InvalidKeyException: Ill
我正在 netbeans 中构建一个桌面应用程序,以便在密码键盘(设备)上加载按键。相同的代码在 android 上运行并且使用 16 字节键可以正常工作但是在桌面应用程序上它会抛出 16 字节错误但
我的任务是通过 LDAP 实现对 Active Directory 联合身份验证服务 (SSL) 的可访问性。起初我不得不说我在 ADFS 和 SAML 方面的经验非常少。我决定采用 Spring S
我正在使用以下示例: http://compscipleslab.wordpress.com/category/java/ 但是我遇到了异常,当我记录异常时,它出现在我的 logcat 中,说明:In
我正在尝试编写一个服务来处理用户密码哈希和验证。我正在使用 Wildfly Elytron 库,并在 quarkus Web 服务的上下文中使用该服务。我遇到的问题是,当我尝试验证密码时,验证方法会抛
这个问题已经有答案了: InvalidKeyException Illegal key size (6 个回答) 已关闭 5 年前。 实际上,我收到 InvalidKeyException: 非法 k
编写代码生成数字证书 这是导致问题的代码段 PBEKeySpec keySpec = new PBEKeySpec(password); SecretKeyFactory keyFactory =
我已将 ODL Netconf 测试工具 (netconf-testtool-1.1.0-Boron-executable.jar) 部署到我的 Nitrogen ODL Controller 上,以
尝试在客户端和服务器之间进行 TLS 握手。但是,更改密码规范步骤失败。同样在客户端收到如下所述的异常:我无法理解为什么我会收到如下奇怪的异常。 这是什么意思?关于如何解决此问题的任何想法? 我在 J
我收到 java.security.InvalidKeyException: Keystore operation failed。有人有想法吗?这是我的代码: initDecodeCipher 代码:
我在我的应用程序中使用 Sun 的 MSCAPI 提供程序来检索签名证书。签名者的私钥是 sun.security.mscapi.RSAPrivateKey。IAIK 似乎无法识别此类(请参阅下面的错
我必须读取 pem key 文件以获得 RSA 公钥,然后使用它们进行加密。我可以使用 openssl 并将 pem 文件转换为 der 文件来执行此操作。然后使用 X509EncodedKeySpe
我是一名优秀的程序员,十分优秀!