首页 > 代码库 > sunJCE or ibmJce,was服务器下使用des的注意点
sunJCE or ibmJce,was服务器下使用des的注意点
最近开发了一个应用,在tomcat下一切ok,到was上有报错。打开debug日志,没有异常??继续调查发现是我们的程序引用了一个sun很久以前的jar.这个jar需要单独打开message日志在一堆日志中找到了:java.security.NoSuchProviderException: no such provider: SunJCE at sun.security.jca.GetInstance.getService(GetInstance.java:82) at javax.crypto.b.a(Unknown Source) at javax.crypto.SecretKeyFactory.getInstance(Unknown Source) atcom.iplanet.services.util.JCEEncryption.setPassword(JCEEncryption.java:369) at com.iplanet.services.util.Crypt.createInstance(Crypt.java:126) at com.iplanet.services.util.Crypt.initialize(Crypt.java:97)这个包里使用了des加密,但是sun的组件,当然是使用sunJDK里自己sunJCE而IBM was服务器里没有这个sunJCE的provider,于是就?no such provider因此,我们只要提供这个sunjce的provider就可以使程序正常运行而无需修改。常规的方法,就是下载sunjce_provider.jar,修改jdk的policy,启用这个jce(这个是jdk的安全配置,不能直接引入相应的jar包)具体IMB的文档参考:http://www.ibm.com/developerworks/websphere/library/techarticles/0306_yu/yu.html不过这个sun的jar包里却预留了解决方案,反编译这个jar,可以看到sun写这个jar的时候提供了配置项(32个赞):CRYPTO_DESCRIPTOR_PROVIDER = System.getProperty("amCryptoDescriptor.provider", "SunJCE"); KEYGEN_ALGORITHM_PROVIDER = System.getProperty("amKeyGenDescriptor.provider", "SunJCE");Cipher.getInstance(CRYPTO_DESCRIPTOR, CRYPTO_DESCRIPTOR_PROVIDER) this.pbeKey = SecretKeyFactory.getInstance(KEYGEN_ALGORITHM, KEYGEN_ALGORITHM_PROVIDER).generateSecret(new PBEKeySpec(paramString.toCharArray()));而IbmJCE与SunJCE都遵循jce1.2.1规范,这里使用是兼容的因此只要添加应用程序的jvm参数 -DamCryptoDescriptor.provider=IBMJCE -DamKeyGenDescriptor.provider=IBMJCE,问题解决下面是官方的说明:https://java.net/projects/opensso/lists/dev/archive/2008-10/message/22-DamCryptoDescriptor.provider=IBMJCE -DamKeyGenDescriptor.provider=IBMJCEERROR: Crypt: failed to set password-based keyjava.security.NoSuchProviderException: no such provider: SunJCE
文章来源:http://blog.xujif.com/archives/sunjce-or-ibmjce.html
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。