当我们使用DES等加密算法时,如下:
Security.addProvider(new com.sun.crypto.provider.SunJCE());
//获得密钥
Key generateKey = new KeyTools().getKey(key.getBytes());
Cipher encryptCipher = Cipher.getInstance("DES");
将用到该算法类对应的工程在Eclipse中发布为web工程,通过Eclipse启动Tomcat服务,可能会遇到这样的异常信息:
java.security.NoSuchAlgorithmException: Cannot find any provider supporting DES
网上的解决方案说什么sunjce_provider.jar路径问题啊,什么需要换成IBM的JDK之类的。。。。。
除了没换JDK,其他的方法都试过,但是没一个起作用的。到底有没有更好的解决方案?
其实很简单,将编译好的工程部署好,直接启动Tomcat而不是通过Eclipse的Tomcat插件启动,那么将不会出现这样的异常信息。
原因剖析:
对Eclipse的jar包,它隐掉了SUN公司关于某些Jar包的签名信息,这样当你在Eclipse中启动服务的话,就可能导致上述的异常。
个人觉得是这样的原因,因为目前为止也没看到有谁有更好的解决方案。