zoukankan      html  css  js  c++  java
  • Caused by: java.security.InvalidKeyException: Illegal key size or default parameters

    How to remove the key size restriction in Java JDK?

    Are you developing your beautiful application using the Java Cryptography Extension, and using a key length of more than 128 bits you encounter the following error?


    Caused by: java.security.InvalidKeyException: Illegal key size or default parameters

    There is nothing wrong that you are doing: JDK has a deliberate key size restriction by default, so you cannot use an encryption with key more than 128 bits.

    From Oracle’s documentation:

    Due to import control restrictions by the governments of a few countries, the jurisdiction policy files shipped with the JDK 5.0 from Sun Microsystems specify that “strong” but limited cryptography may be used.

    Some countries have restrictions on the permitted key strength used in encryption algorithms:

    An “unlimited strength” version of these files indicating no restrictions on cryptographic strengths is available for those living in eligible countries (which is most countries). But only the “strong” version can be imported into those countries whose governments mandate restrictions. The JCE framework will enforce the restrictions specified in the installed jurisdiction policy files.


    How to remove the key size restriction?

    You can remove the maximum key restriction by replacing the existing JCE jars with unlimited strength policy jars.

    Copy local_policy.jar and US_export_policy.jar extracted from above zip file to the $JAVA_HOME/jre/lib/security

    Then simply restart you java application and the Exception should be gone.

    from:https://www.andreafortuna.org/java/java-tips-how-to-fix-the-invalidkeyexception-illegal-key-size-or-default-parameters-runtime/

    如果不方便覆盖文件,可以在代码中通过反射修改,在main中调用一下方法就Ok了:

    /**
         * 去除JCE限制
         */
        private static void removeJceLimit()
        {
            //去除JCE加密限制,只限于Java1.8
            try {
                Field field = Class.forName("javax.crypto.JceSecurity").getDeclaredField("isRestricted");
                field.setAccessible(true);
    
                Field modifiersField = Field.class.getDeclaredField("modifiers");
                modifiersField.setAccessible(true);
                modifiersField.setInt(field, field.getModifiers() & ~Modifier.FINAL);
    
                field.set(null, false);
    
                LOGGER.info("============= remove the key size restriction Success =============");
    
            } catch (ClassNotFoundException | NoSuchFieldException | SecurityException | IllegalArgumentException | IllegalAccessException ex) {
                ex.printStackTrace(System.err);
            }
        }
  • 相关阅读:
    JMX堆栈分析
    Python装饰器示例
    安装指定版本capistrano
    Linux CPU使用率含义及原理
    API gateway 之 kong 安装
    Redis内存分析方法
    Elasticsearch集群内的原理
    Elasticsearch基础
    Python智能检测编码并转码
    (转)rabbitmq的web管理界面无法使用guest用户登录
  • 原文地址:https://www.cnblogs.com/zjoch/p/9674508.html
Copyright © 2011-2022 走看看