Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
94d8011a
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
94d8011a
编写于
6月 22, 2016
作者:
A
aefimov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8146490: Direct indirect CRL checks
Reviewed-by: vinnie
上级
50bd8001
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
86 addition
and
9 deletion
+86
-9
src/share/classes/sun/security/ec/CurveDB.java
src/share/classes/sun/security/ec/CurveDB.java
+69
-1
src/share/classes/sun/security/provider/certpath/ForwardBuilder.java
...lasses/sun/security/provider/certpath/ForwardBuilder.java
+17
-8
未找到文件。
src/share/classes/sun/security/ec/CurveDB.java
浏览文件 @
94d8011a
/*
* Copyright (c) 2006, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2006, 201
6
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
...
...
@@ -664,6 +664,74 @@ public class CurveDB {
0xFF70, nameSplitPattern);
*/
/*
* Brainpool curves (RFC 5639)
* (Twisted curves are not included)
*/
add
(
"brainpoolP160r1"
,
"1.3.36.3.3.2.8.1.1.1"
,
P
,
"E95E4A5F737059DC60DFC7AD95B3D8139515620F"
,
"340E7BE2A280EB74E2BE61BADA745D97E8F7C300"
,
"1E589A8595423412134FAA2DBDEC95C8D8675E58"
,
"BED5AF16EA3F6A4F62938C4631EB5AF7BDBCDBC3"
,
"1667CB477A1A8EC338F94741669C976316DA6321"
,
"E95E4A5F737059DC60DF5991D45029409E60FC09"
,
1
,
nameSplitPattern
);
add
(
"brainpoolP192r1"
,
"1.3.36.3.3.2.8.1.1.3"
,
P
,
"C302F41D932A36CDA7A3463093D18DB78FCE476DE1A86297"
,
"6A91174076B1E0E19C39C031FE8685C1CAE040E5C69A28EF"
,
"469A28EF7C28CCA3DC721D044F4496BCCA7EF4146FBF25C9"
,
"C0A0647EAAB6A48753B033C56CB0F0900A2F5C4853375FD6"
,
"14B690866ABD5BB88B5F4828C1490002E6773FA2FA299B8F"
,
"C302F41D932A36CDA7A3462F9E9E916B5BE8F1029AC4ACC1"
,
1
,
nameSplitPattern
);
add
(
"brainpoolP224r1"
,
"1.3.36.3.3.2.8.1.1.5"
,
P
,
"D7C134AA264366862A18302575D1D787B09F075797DA89F57EC8C0FF"
,
"68A5E62CA9CE6C1C299803A6C1530B514E182AD8B0042A59CAD29F43"
,
"2580F63CCFE44138870713B1A92369E33E2135D266DBB372386C400B"
,
"0D9029AD2C7E5CF4340823B2A87DC68C9E4CE3174C1E6EFDEE12C07D"
,
"58AA56F772C0726F24C6B89E4ECDAC24354B9E99CAA3F6D3761402CD"
,
"D7C134AA264366862A18302575D0FB98D116BC4B6DDEBCA3A5A7939F"
,
1
,
nameSplitPattern
);
add
(
"brainpoolP256r1"
,
"1.3.36.3.3.2.8.1.1.7"
,
P
,
"A9FB57DBA1EEA9BC3E660A909D838D726E3BF623D52620282013481D1F6E5377"
,
"7D5A0975FC2C3057EEF67530417AFFE7FB8055C126DC5C6CE94A4B44F330B5D9"
,
"26DC5C6CE94A4B44F330B5D9BBD77CBF958416295CF7E1CE6BCCDC18FF8C07B6"
,
"8BD2AEB9CB7E57CB2C4B482FFC81B7AFB9DE27E1E3BD23C23A4453BD9ACE3262"
,
"547EF835C3DAC4FD97F8461A14611DC9C27745132DED8E545C1D54C72F046997"
,
"A9FB57DBA1EEA9BC3E660A909D838D718C397AA3B561A6F7901E0E82974856A7"
,
1
,
nameSplitPattern
);
add
(
"brainpoolP320r1"
,
"1.3.36.3.3.2.8.1.1.9"
,
P
,
"D35E472036BC4FB7E13C785ED201E065F98FCFA6F6F40DEF4F92B9EC7893EC28FCD412B1F1B32E27"
,
"3EE30B568FBAB0F883CCEBD46D3F3BB8A2A73513F5EB79DA66190EB085FFA9F492F375A97D860EB4"
,
"520883949DFDBC42D3AD198640688A6FE13F41349554B49ACC31DCCD884539816F5EB4AC8FB1F1A6"
,
"43BD7E9AFB53D8B85289BCC48EE5BFE6F20137D10A087EB6E7871E2A10A599C710AF8D0D39E20611"
,
"14FDD05545EC1CC8AB4093247F77275E0743FFED117182EAA9C77877AAAC6AC7D35245D1692E8EE1"
,
"D35E472036BC4FB7E13C785ED201E065F98FCFA5B68F12A32D482EC7EE8658E98691555B44C59311"
,
1
,
nameSplitPattern
);
add
(
"brainpoolP384r1"
,
"1.3.36.3.3.2.8.1.1.11"
,
P
,
"8CB91E82A3386D280F5D6F7E50E641DF152F7109ED5456B412B1DA197FB71123ACD3A729901D1A71874700133107EC53"
,
"7BC382C63D8C150C3C72080ACE05AFA0C2BEA28E4FB22787139165EFBA91F90F8AA5814A503AD4EB04A8C7DD22CE2826"
,
"04A8C7DD22CE28268B39B55416F0447C2FB77DE107DCD2A62E880EA53EEB62D57CB4390295DBC9943AB78696FA504C11"
,
"1D1C64F068CF45FFA2A63A81B7C13F6B8847A3E77EF14FE3DB7FCAFE0CBD10E8E826E03436D646AAEF87B2E247D4AF1E"
,
"8ABE1D7520F9C2A45CB1EB8E95CFD55262B70B29FEEC5864E19C054FF99129280E4646217791811142820341263C5315"
,
"8CB91E82A3386D280F5D6F7E50E641DF152F7109ED5456B31F166E6CAC0425A7CF3AB6AF6B7FC3103B883202E9046565"
,
1
,
nameSplitPattern
);
add
(
"brainpoolP512r1"
,
"1.3.36.3.3.2.8.1.1.13"
,
P
,
"AADD9DB8DBE9C48B3FD4E6AE33C9FC07CB308DB3B3C9D20ED6639CCA703308717D4D9B009BC66842AECDA12AE6A380E62881FF2F2D82C68528AA6056583A48F3"
,
"7830A3318B603B89E2327145AC234CC594CBDD8D3DF91610A83441CAEA9863BC2DED5D5AA8253AA10A2EF1C98B9AC8B57F1117A72BF2C7B9E7C1AC4D77FC94CA"
,
"3DF91610A83441CAEA9863BC2DED5D5AA8253AA10A2EF1C98B9AC8B57F1117A72BF2C7B9E7C1AC4D77FC94CADC083E67984050B75EBAE5DD2809BD638016F723"
,
"81AEE4BDD82ED9645A21322E9C4C6A9385ED9F70B5D916C1B43B62EEF4D0098EFF3B1F78E2D0D48D50D1687B93B97D5F7C6D5047406A5E688B352209BCB9F822"
,
"7DDE385D566332ECC0EABFA9CF7822FDF209F70024A57B1AA000C55B881F8111B2DCDE494A5F485E5BCA4BD88A2763AED1CA2B2FA8F0540678CD1E0F3AD80892"
,
"AADD9DB8DBE9C48B3FD4E6AE33C9FC07CB308DB3B3C9D20ED6639CCA70330870553E5C414CA92619418661197FAC10471DB1D381085DDADDB58796829CA90069"
,
1
,
nameSplitPattern
);
specCollection
=
Collections
.
unmodifiableCollection
(
oidMap
.
values
());
}
}
src/share/classes/sun/security/provider/certpath/ForwardBuilder.java
浏览文件 @
94d8011a
/*
* Copyright (c) 2000, 201
5
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2000, 201
6
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
...
...
@@ -816,18 +816,22 @@ class ForwardBuilder extends Builder {
/**
* Verifies whether the input certificate completes the path.
* Checks the cert against each trust anchor that was specified, in order,
* and returns true as soon as it finds a valid anchor.
* Returns true if the cert matches a trust anchor specified as a
* certificate or if the cert verifies with a trust anchor that
* was specified as a trusted {pubkey, caname} pair. Returns false if none
* of the trust anchors are valid for this cert.
* First checks the cert against each trust anchor that was specified,
* in order, and returns true if the cert matches the trust anchor
* specified as a certificate or has the same key and subject of an anchor
* specified as a trusted {pubkey, caname} pair.
* If no match has been found, does a second check of the cert against
* anchors specified as a trusted {pubkey, caname} pair to see if the cert
* was issued by that anchor.
* Returns false if none of the trust anchors are valid for this cert.
*
* @param cert the certificate to test
* @return a boolean value indicating whether the cert completes the path.
*/
@Override
boolean
isPathCompleted
(
X509Certificate
cert
)
{
List
<
TrustAnchor
>
otherAnchors
=
new
ArrayList
<>();
// first, check if cert is already trusted
for
(
TrustAnchor
anchor
:
trustAnchors
)
{
if
(
anchor
.
getTrustedCert
()
!=
null
)
{
if
(
cert
.
equals
(
anchor
.
getTrustedCert
()))
{
...
...
@@ -849,7 +853,12 @@ class ForwardBuilder extends Builder {
}
// else, it is a self-issued certificate of the anchor
}
otherAnchors
.
add
(
anchor
);
}
// next, check if cert is issued by anchor specified by key/name
for
(
TrustAnchor
anchor
:
otherAnchors
)
{
X500Principal
principal
=
anchor
.
getCA
();
PublicKey
publicKey
=
anchor
.
getCAPublicKey
();
// Check subject/issuer name chaining
if
(
principal
==
null
||
!
principal
.
equals
(
cert
.
getIssuerX500Principal
()))
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录