Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Openssl
提交
4f6235f7
T
Third Party Openssl
项目概览
OpenHarmony
/
Third Party Openssl
1 年多 前同步成功
通知
10
Star
18
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Openssl
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
4f6235f7
编写于
7月 15, 1999
作者:
U
Ulf Möller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
RSA private keys without dmp1/dmq1/iqmp are also valid (but slower).
上级
9a3bbbce
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
45 addition
and
35 deletion
+45
-35
crypto/rsa/rsa_chk.c
crypto/rsa/rsa_chk.c
+45
-35
未找到文件。
crypto/rsa/rsa_chk.c
浏览文件 @
4f6235f7
...
...
@@ -104,41 +104,6 @@ int RSA_check_key(RSA *key)
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_N_DOES_NOT_EQUAL_P_Q
);
}
/* dmp1 = d mod (p-1)? */
r
=
BN_sub
(
i
,
key
->
p
,
BN_value_one
());
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
r
=
BN_mod
(
j
,
key
->
d
,
i
,
ctx
);
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
if
(
BN_cmp
(
j
,
key
->
dmp1
)
!=
0
)
{
ret
=
0
;
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_DMP1_NOT_CONGRUENT_TO_D
);
}
/* dmq1 = d mod (q-1)? */
r
=
BN_sub
(
i
,
key
->
q
,
BN_value_one
());
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
r
=
BN_mod
(
j
,
key
->
d
,
i
,
ctx
);
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
if
(
BN_cmp
(
j
,
key
->
dmq1
)
!=
0
)
{
ret
=
0
;
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_DMQ1_NOT_CONGRUENT_TO_D
);
}
/* iqmp = q^-1 mod p? */
if
(
!
BN_mod_inverse
(
i
,
key
->
q
,
key
->
p
,
ctx
))
{
ret
=
-
1
;
goto
err
;
}
if
(
BN_cmp
(
i
,
key
->
iqmp
)
!=
0
)
{
ret
=
0
;
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_IQMP_NOT_INVERSE_OF_Q
);
}
/* d*e = 1 mod lcm(p-1,q-1)? */
r
=
BN_sub
(
i
,
key
->
p
,
BN_value_one
());
...
...
@@ -163,6 +128,51 @@ int RSA_check_key(RSA *key)
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_D_E_NOT_CONGRUENT_TO_1
);
}
if
(
key
->
dmp1
!=
NULL
&&
key
->
dmq1
!=
NULL
&&
key
->
iqmp
!=
NULL
)
{
/* dmp1 = d mod (p-1)? */
r
=
BN_sub
(
i
,
key
->
p
,
BN_value_one
());
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
r
=
BN_mod
(
j
,
key
->
d
,
i
,
ctx
);
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
if
(
BN_cmp
(
j
,
key
->
dmp1
)
!=
0
)
{
ret
=
0
;
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_DMP1_NOT_CONGRUENT_TO_D
);
}
/* dmq1 = d mod (q-1)? */
r
=
BN_sub
(
i
,
key
->
q
,
BN_value_one
());
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
r
=
BN_mod
(
j
,
key
->
d
,
i
,
ctx
);
if
(
!
r
)
{
ret
=
-
1
;
goto
err
;
}
if
(
BN_cmp
(
j
,
key
->
dmq1
)
!=
0
)
{
ret
=
0
;
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_DMQ1_NOT_CONGRUENT_TO_D
);
}
/* iqmp = q^-1 mod p? */
if
(
!
BN_mod_inverse
(
i
,
key
->
q
,
key
->
p
,
ctx
))
{
ret
=
-
1
;
goto
err
;
}
if
(
BN_cmp
(
i
,
key
->
iqmp
)
!=
0
)
{
ret
=
0
;
RSAerr
(
RSA_F_RSA_CHECK_KEY
,
RSA_R_IQMP_NOT_INVERSE_OF_Q
);
}
}
err:
if
(
i
!=
NULL
)
BN_free
(
i
);
if
(
j
!=
NULL
)
BN_free
(
j
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录