产出密钥时经常会出现java.security.NoSuchAlgorithmException异常。如下面代码,在elipse中编译通过,但运行时会抛出java.security.NoSuchAlgorithmException异常
KeyGenerator keyGen=null;
keyGen = KeyGenerator.getInstance("DES");
keyGen.init(56);
Key key = keyGen.generateKey();
根据jdk的文档,从1.4开始就把jce集成起来了,而且在%javahome%/lib/ext里的确存在sunjce_provider.jar,里面包含了com.sun.crypto.provider.SunJCE。在elipse里运行时抛出异常的原因是,class在eclipse里运行时,是通过eclipse的进行classload时会把com.sun.crypto.provider.SunJCE的签名信息往掉,这样JCE就不认这个类了,导致找不到Provider的实现,解决办法:在eclipse的preferences->java->installed jres里选择你指定的jre,edit,将Use default system libraries选上就可以正常运行了。实在把上面的程序在eclipse里编译好,直接在命令行下run,是不会出现上面的异常信息了。
在其它的一些情况下抛出java.security.NoSuchAlgorithmException的话,也可以考虑是不是在通过其它的程序进行classload时往掉了签名信息。
分享到:
相关推荐
java.security.NoSuchAlgorithmException: SHA1PRNG SecureRandom not available at sun.security.jca.GetInstance.getInstance(GetInstance.java:142) at java.security.SecureRandom.getInstance(SecureRandom....
Exception in thread "main" java.security.NoSuchAlgorithmException: Cannot find any provider supporting AES/ECB/PKCS7Padding https://www.codeprj.com/blog/92cdc41.html
import java.security.NoSuchAlgorithmException; import java.security.PrivateKey; import java.security.PublicKey; public class RSAKeys { public static void main(String[] args) throws ...
import java.security.NoSuchAlgorithmException; public String encryptToMD5(String info) { try { MessageDigest md = MessageDigest.getInstance("MD5"); md.update(info.getBytes()); byte[] digestBytes ...
Struts2是一个流行的Java Web应用程序框架,它继承和发展了Struts1.x的一些特性,同时又采用了WebWork框架的核心技术,使得Struts2在设计理念和技术实现上都有了显著的进步。 #### Struts2与WebWork的关系 Struts2...
标注使用java.security.SecureRandom在策略Apigee Edge代理内生成随机数(int,UUID或高斯值),并使用该信息设置上下文变量。免责声明此示例不是正式的Google产品,也不是正式的Google产品的一部分。使用此标注您...
import java.security.NoSuchAlgorithmException; import java.security.PrivateKey; import java.security.cert.Certificate; import java.security.cert.CertificateFactory; import java.security.cert.X509...
import java.security.NoSuchAlgorithmException; public class MD5Example { public static String getMD5(String input) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] ...
import java.security.NoSuchAlgorithmException; public class MD5Util { public static String getMD5(String input) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] bytes = md....
import java.security.NoSuchAlgorithmException; public class SHA1Example { public static void main(String[] args) { try { File file = new File("待计算文件的路径"); MessageDigest digest = ...
2. 创建MessageDigest实例:使用`java.security.MessageDigest.getInstance("SHA1")`获取SHA1实例。 3. 更新数据:调用`digest.update()`方法添加要签名的数据。 4. 生成哈希值:通过`digest.digest()`方法获取哈希...
import java.security.NoSuchAlgorithmException;public class HashUtil { public static String sha256(String data) throws NoSuchAlgorithmException { MessageDigest messageDigest = MessageDigest.getInstance...
import java.security.NoSuchAlgorithmException; public class MD5Example { public static String getMD5(String input) throws NoSuchAlgorithmException { MessageDigest md = MessageDigest.getInstance("MD...
import java.security.NoSuchAlgorithmException; import javax.crypto.Cipher; // 保存密钥到文件 public void saveKeys(PublicKey publicKey, PrivateKey privateKey, String publicKeyPath, String ...
import java.security.NoSuchAlgorithmException; public class MD5Example { public static byte[] encryptMD5(byte[] data) throws NoSuchAlgorithmException { MessageDigest md5 = MessageDigest.getInstance...
在Java环境中,我们通常会借助第三方库如BouncyCastle来创建和处理这种格式的证书。本文将深入探讨如何使用BouncyCastle库在Java中创建PKCS12格式的数字签名证书。 首先,理解BouncyCastle库。BouncyCastle是一个...
import java.security.NoSuchAlgorithmException; public class MD5Util { public static String encrypt(String input) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] bytes = md....
import java.security.NoSuchAlgorithmException; import java.security.NoSuchProviderException; import java.security.SecureRandom; import java.util.ArrayList; import java.util.HashMap; import java.util....
import java.security.NoSuchAlgorithmException; public class SHAUtil { public static byte[] sha256(String input) throws NoSuchAlgorithmException { MessageDigest digest = MessageDigest.getInstance(...
import java.security.NoSuchAlgorithmException; public String calculateMD5(String input) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] messageDigest = md.digest(input.getBytes...