作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
网上经常看到参数jdk.tls.disabledAlgorithms的配置例子(设置在java.security文件中),例如:
jdk.certpath.disabledAlgorithms=MD2, RSA keySize < 1024
是否有详尽的列表/指南来设置此参数的值,即它可以采用哪些值,以及如何构建这些值。
最佳答案
来自 java.security 文件(如 EJP 在评论中提到的):
In some environments, certain algorithms or key lengths may be undesirable
for certification path building and validation. For example, "MD2" is
generally no longer considered to be a secure hash algorithm. This section
describes the mechanism for disabling algorithms based on algorithm name
and/or key length. This includes algorithms used in certificates, as well
as revocation information such as CRLs and signed OCSP Responses.
The syntax of the disabled algorithm string is described as this Java
BNF-style:
DisabledAlgorithms:
" DisabledAlgorithm { , DisabledAlgorithm } "
DisabledAlgorithm:
AlgorithmName [Constraint]
AlgorithmName:
(see below)
Constraint:
KeySizeConstraint
KeySizeConstraint:
keySize Operator DecimalInteger
Operator:
<= | < | == | != | >= | >
DecimalInteger:
DecimalDigits
DecimalDigits:
DecimalDigit {DecimalDigit}
DecimalDigit: one of
1 2 3 4 5 6 7 8 9 0
The "AlgorithmName" is the standard algorithm name of the disabled
algorithm. See "Java Cryptography Architecture Standard Algorithm Name
Documentation" for information about Standard Algorithm Names. Matching
is performed using a case-insensitive sub-element matching rule. (For
example, in "SHA1withECDSA" the sub-elements are "SHA1" for hashing and
"ECDSA" for signatures.) If the assertion "AlgorithmName" is a
sub-element of the certificate algorithm name, the algorithm will be
rejected during certification path building and validation. For example,
the assertion algorithm name "DSA" will disable all certificate algorithms
that rely on DSA, such as NONEwithDSA, SHA1withDSA. However, the assertion
will not disable algorithms related to "ECDSA".
A "Constraint" provides further guidance for the algorithm being specified.
The "KeySizeConstraint" requires a key of a valid size range if the
"AlgorithmName" is of a key algorithm. The "DecimalInteger" indicates the
key size specified in number of bits. For example, "RSA keySize <= 1024"
indicates that any RSA key with key size less than or equal to 1024 bits
should be disabled, and "RSA keySize < 1024, RSA keySize > 2048" indicates
that any RSA key with key size less than 1024 or greater than 2048 should
be disabled. Note that the "KeySizeConstraint" only makes sense to key
algorithms.
Note: This property is currently used by Oracle's PKIX implementation. It
is not guaranteed to be examined and used by other implementations.
Example:
jdk.certpath.disabledAlgorithms=MD2, DSA, RSA keySize < 2048
关于java - 安全参数 jdk.tls.disabledAlgorithms 的有效值是多少,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38716969/
我可以为属性 contenteditable 选择什么值。 最佳答案 它可以包含: true 错误 继承 引用: The contentEditable DOM attribute, on getti
我在签署 Ionic android apk 时遇到此错误,我在 Kubuntu 17.04 上,使用 Ionic 3,安装了 java 8 我得到的错误: Enter Passphrase for
我是一名优秀的程序员,十分优秀!