Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Xts Acts
提交
8bf51f86
X
Xts Acts
项目概览
OpenHarmony
/
Xts Acts
1 年多 前同步成功
通知
9
Star
22
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
X
Xts Acts
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
8bf51f86
编写于
3月 15, 2023
作者:
O
openharmony_ci
提交者:
Gitee
3月 15, 2023
浏览文件
操作
浏览文件
下载
差异文件
!8006 适配必选算法2
Merge pull request !8006 from 伞木希美/master
上级
f18ef0eb
c45b8969
变更
18
展开全部
隐藏空白更改
内联
并排
Showing
18 changed file
with
1945 addition
and
1851 deletion
+1945
-1851
security/huks_napi_BasicTest/include/huks_three_stage_test_common.h
...uks_napi_BasicTest/include/huks_three_stage_test_common.h
+1
-0
security/huks_napi_BasicTest/src/huks_attest_test.cpp
security/huks_napi_BasicTest/src/huks_attest_test.cpp
+24
-18
security/huks_napi_BasicTest/src/huks_derive_pbkdf_test.cpp
security/huks_napi_BasicTest/src/huks_derive_pbkdf_test.cpp
+2
-7
security/huks_napi_BasicTest/src/huks_signverify_dsa_test.cpp
...rity/huks_napi_BasicTest/src/huks_signverify_dsa_test.cpp
+28
-22
security/huks_napi_BasicTest/src/huks_three_stage_test_common.cpp
.../huks_napi_BasicTest/src/huks_three_stage_test_common.cpp
+26
-0
security/security_huks_basic/huks_hmac_callback_BasicTest/src/main/js/test/HMAC/SecurityHuksImportJsunit.test.js
...st/src/main/js/test/HMAC/SecurityHuksImportJsunit.test.js
+16
-14
security/security_huks_reformed_test/huks_hmac_callback_BasicTest/src/main/js/test/HMAC/SecurityHuksImportJsunit.test.js
...st/src/main/js/test/HMAC/SecurityHuksImportJsunit.test.js
+65
-57
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort63KBCallbackJsunit.test.js
...erify/SecurityHuksDSABasicAbort63KBCallbackJsunit.test.js
+1
-1
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort65KBCallbackJsunit.test.js
...erify/SecurityHuksDSABasicAbort65KBCallbackJsunit.test.js
+1
-1
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish63KBCallbackJsunit.test.js
...rify/SecurityHuksDSABasicFinish63KBCallbackJsunit.test.js
+1
-1
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish65KBCallbackJsunit.test.js
...rify/SecurityHuksDSABasicFinish65KBCallbackJsunit.test.js
+1
-1
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort63KBPromiseJsunit.test.js
...Verify/SecurityHuksDSABasicAbort63KBPromiseJsunit.test.js
+1
-1
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort65KBPromiseJsunit.test.js
...Verify/SecurityHuksDSABasicAbort65KBPromiseJsunit.test.js
+2
-2
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish63KBPromiseJsunit.test.js
...erify/SecurityHuksDSABasicFinish63KBPromiseJsunit.test.js
+1
-1
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish65KBPromiseJsunit.test.js
...erify/SecurityHuksDSABasicFinish65KBPromiseJsunit.test.js
+1
-1
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksECCBasicFinish65KBPromiseJsunit.test.js
...erify/SecurityHuksECCBasicFinish65KBPromiseJsunit.test.js
+452
-435
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksRSABasicFinish65KBPromiseJsunit.test.js
...erify/SecurityHuksRSABasicFinish65KBPromiseJsunit.test.js
+1192
-1169
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksRSASignExtendJsunit.test.js
...s/test/SignVerify/SecurityHuksRSASignExtendJsunit.test.js
+130
-120
未找到文件。
security/huks_napi_BasicTest/include/huks_three_stage_test_common.h
浏览文件 @
8bf51f86
...
@@ -92,6 +92,7 @@ extern "C"
...
@@ -92,6 +92,7 @@ extern "C"
const
struct
OH_Huks_Blob
*
keyAlias
,
const
struct
OH_Huks_Blob
*
keyAlias
,
const
struct
OH_Huks_Blob
*
peerPublicKey
,
const
struct
OH_Huks_Blob
*
peerPublicKey
,
struct
OH_Huks_Blob
*
agreedKey
);
struct
OH_Huks_Blob
*
agreedKey
);
bool
checkUseSoftware
();
#ifdef __cplusplus
#ifdef __cplusplus
}
}
#endif
#endif
...
...
security/huks_napi_BasicTest/src/huks_attest_test.cpp
浏览文件 @
8bf51f86
...
@@ -23,6 +23,7 @@ namespace Unittest::AttestKey {
...
@@ -23,6 +23,7 @@ namespace Unittest::AttestKey {
static
struct
OH_Huks_Blob
g_secInfo
=
{
sizeof
(
SEC_INFO_DATA
),
(
uint8_t
*
)
SEC_INFO_DATA
};
static
struct
OH_Huks_Blob
g_secInfo
=
{
sizeof
(
SEC_INFO_DATA
),
(
uint8_t
*
)
SEC_INFO_DATA
};
static
struct
OH_Huks_Blob
g_challenge
=
{
sizeof
(
CHALLENGE_DATA
),
(
uint8_t
*
)
CHALLENGE_DATA
};
static
struct
OH_Huks_Blob
g_challenge
=
{
sizeof
(
CHALLENGE_DATA
),
(
uint8_t
*
)
CHALLENGE_DATA
};
static
struct
OH_Huks_Blob
g_version
=
{
sizeof
(
VERSION_DATA
),
(
uint8_t
*
)
VERSION_DATA
};
static
struct
OH_Huks_Blob
g_version
=
{
sizeof
(
VERSION_DATA
),
(
uint8_t
*
)
VERSION_DATA
};
bool
useSoftware
=
true
;
class
HuksAttestKeyNoIdsTest
:
public
testing
::
Test
{
class
HuksAttestKeyNoIdsTest
:
public
testing
::
Test
{
public:
public:
...
@@ -37,6 +38,7 @@ public:
...
@@ -37,6 +38,7 @@ public:
void
HuksAttestKeyNoIdsTest
::
SetUpTestCase
(
void
)
void
HuksAttestKeyNoIdsTest
::
SetUpTestCase
(
void
)
{
{
useSoftware
=
checkUseSoftware
();
}
}
void
HuksAttestKeyNoIdsTest
::
TearDownTestCase
(
void
)
void
HuksAttestKeyNoIdsTest
::
TearDownTestCase
(
void
)
...
@@ -68,23 +70,27 @@ static const struct OH_Huks_Param g_commonParams[] = {
...
@@ -68,23 +70,27 @@ static const struct OH_Huks_Param g_commonParams[] = {
*/
*/
HWTEST_F
(
HuksAttestKeyNoIdsTest
,
Security_HUKS_NAPI_Attest_0100
,
TestSize
.
Level0
)
HWTEST_F
(
HuksAttestKeyNoIdsTest
,
Security_HUKS_NAPI_Attest_0100
,
TestSize
.
Level0
)
{
{
OH_Huks_Result
ret
=
TestGenerateKey
(
&
g_keyAlias
);
if
(
useSoftware
)
ASSERT_TRUE
(
ret
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
{
struct
OH_Huks_ParamSet
*
paramSet
=
NULL
;
OH_Huks_Result
ret
=
TestGenerateKey
(
&
g_keyAlias
);
GenerateParamSet
(
&
paramSet
,
g_commonParams
,
sizeof
(
g_commonParams
)
/
sizeof
(
g_commonParams
[
0
]));
ASSERT_TRUE
(
ret
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
OH_Huks_CertChain
*
certChain
=
NULL
;
struct
OH_Huks_ParamSet
*
paramSet
=
NULL
;
const
struct
HksTestCertChain
certParam
=
{
true
,
true
,
true
,
g_size
};
GenerateParamSet
(
&
paramSet
,
g_commonParams
,
sizeof
(
g_commonParams
)
/
sizeof
(
g_commonParams
[
0
]));
(
void
)
ConstructDataToCertChain
(
&
certChain
,
&
certParam
);
OH_Huks_CertChain
*
certChain
=
NULL
;
ret
=
OH_Huks_AttestKeyItem
(
&
g_keyAlias
,
paramSet
,
certChain
);
const
struct
HksTestCertChain
certParam
=
{
true
,
true
,
true
,
g_size
};
ASSERT_TRUE
(
ret
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
(
void
)
ConstructDataToCertChain
(
&
certChain
,
&
certParam
);
ret
=
ValidateCertChainTest
(
certChain
,
g_commonParams
,
NON_IDS_PARAM
);
ret
=
OH_Huks_AttestKeyItem
(
&
g_keyAlias
,
paramSet
,
certChain
);
ASSERT_TRUE
(
ret
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
ASSERT_TRUE
(
ret
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
FreeCertChain
(
&
certChain
,
certChain
->
certsCount
);
ret
=
ValidateCertChainTest
(
certChain
,
g_commonParams
,
NON_IDS_PARAM
);
certChain
=
NULL
;
ASSERT_TRUE
(
ret
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
FreeCertChain
(
&
certChain
,
certChain
->
certsCount
);
OH_Huks_FreeParamSet
(
&
paramSet
);
certChain
=
NULL
;
OH_Huks_Result
ret1
=
OH_Huks_DeleteKeyItem
(
&
g_keyAlias
,
NULL
);
OH_Huks_FreeParamSet
(
&
paramSet
);
ASSERT_TRUE
(
ret1
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
OH_Huks_Result
ret1
=
OH_Huks_DeleteKeyItem
(
&
g_keyAlias
,
NULL
);
ASSERT_TRUE
(
ret1
.
errorCode
==
(
int32_t
)
OH_HUKS_SUCCESS
);
}
ASSERT_TRUE
(
0
==
0
);
}
}
}
}
security/huks_napi_BasicTest/src/huks_derive_pbkdf_test.cpp
浏览文件 @
8bf51f86
...
@@ -48,7 +48,6 @@ void HuksDerivePBKDFTest::TearDown()
...
@@ -48,7 +48,6 @@ void HuksDerivePBKDFTest::TearDown()
{
{
}
}
uint8_t
g_saltdata1
[
16
]
=
{
0
};
uint8_t
g_saltgen
[
16
]
=
{
uint8_t
g_saltgen
[
16
]
=
{
0x14
,
0x10
,
0x11
,
0x3a
,
0x27
,
0x9e
,
0xc8
,
0x5f
,
0xe0
,
0xf3
,
0x36
,
0x17
,
0x57
,
0x42
,
0x8e
,
0xff
0x14
,
0x10
,
0x11
,
0x3a
,
0x27
,
0x9e
,
0xc8
,
0x5f
,
0xe0
,
0xf3
,
0x36
,
0x17
,
0x57
,
0x42
,
0x8e
,
0xff
};
};
...
@@ -96,8 +95,8 @@ static struct OH_Huks_Param g_pbkdf2Params001[] = {
...
@@ -96,8 +95,8 @@ static struct OH_Huks_Param g_pbkdf2Params001[] = {
},
{
},
{
.
tag
=
OH_HUKS_TAG_SALT
,
.
tag
=
OH_HUKS_TAG_SALT
,
.
blob
=
{
.
blob
=
{
sizeof
(
g_salt
data1
),
sizeof
(
g_salt
gen
),
(
uint8_t
*
)
g_salt
data1
(
uint8_t
*
)
g_salt
gen
}
}
},
{
},
{
.
tag
=
OH_HUKS_TAG_DERIVE_KEY_SIZE
,
.
tag
=
OH_HUKS_TAG_DERIVE_KEY_SIZE
,
...
@@ -148,10 +147,6 @@ HWTEST_F(HuksDerivePBKDFTest, Security_HUKS_NAPI_Derive_pbkdf_0100, TestSize.Lev
...
@@ -148,10 +147,6 @@ HWTEST_F(HuksDerivePBKDFTest, Security_HUKS_NAPI_Derive_pbkdf_0100, TestSize.Lev
struct
OH_Huks_ParamSet
*
pbkdf2FinishParamSet
=
nullptr
;
struct
OH_Huks_ParamSet
*
pbkdf2FinishParamSet
=
nullptr
;
ret
=
InitParamSet
(
&
pbkdf2ParamSet
,
g_pbkdf2Params001
,
sizeof
(
g_pbkdf2Params001
)
/
sizeof
(
OH_Huks_Param
));
ret
=
InitParamSet
(
&
pbkdf2ParamSet
,
g_pbkdf2Params001
,
sizeof
(
g_pbkdf2Params001
)
/
sizeof
(
OH_Huks_Param
));
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
struct
OH_Huks_Param
*
saltParam
=
nullptr
;
OH_Huks_GetParam
(
pbkdf2ParamSet
,
OH_HUKS_TAG_SALT
,
&
saltParam
);
int32_t
ret1
=
HksGenerateRandom
(
NULL
,
(
struct
HksBlob
*
)
&
(
saltParam
->
blob
));
EXPECT_EQ
(
ret1
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"GenerateRandom failed."
;
// Finish paramset
// Finish paramset
ret
=
InitParamSet
(
&
pbkdf2FinishParamSet
,
g_pbkdf2FinishParams001
,
ret
=
InitParamSet
(
&
pbkdf2FinishParamSet
,
g_pbkdf2FinishParams001
,
sizeof
(
g_pbkdf2FinishParams001
)
/
sizeof
(
OH_Huks_Param
));
sizeof
(
g_pbkdf2FinishParams001
)
/
sizeof
(
OH_Huks_Param
));
...
...
security/huks_napi_BasicTest/src/huks_signverify_dsa_test.cpp
浏览文件 @
8bf51f86
...
@@ -19,6 +19,7 @@
...
@@ -19,6 +19,7 @@
using
namespace
testing
::
ext
;
using
namespace
testing
::
ext
;
namespace
Unittest
::
DsaSignVerify
{
namespace
Unittest
::
DsaSignVerify
{
bool
useSoftware
=
true
;
class
HuksSignVerifyDSATest
:
public
testing
::
Test
{
class
HuksSignVerifyDSATest
:
public
testing
::
Test
{
public:
public:
static
void
SetUpTestCase
(
void
);
static
void
SetUpTestCase
(
void
);
...
@@ -32,6 +33,7 @@ public:
...
@@ -32,6 +33,7 @@ public:
void
HuksSignVerifyDSATest
::
SetUpTestCase
(
void
)
void
HuksSignVerifyDSATest
::
SetUpTestCase
(
void
)
{
{
useSoftware
=
checkUseSoftware
();
}
}
void
HuksSignVerifyDSATest
::
TearDownTestCase
(
void
)
void
HuksSignVerifyDSATest
::
TearDownTestCase
(
void
)
...
@@ -163,28 +165,32 @@ OH_Huks_Result HksDsaSignVerifyTestNormalCase(struct OH_Huks_Blob keyAlias, stru
...
@@ -163,28 +165,32 @@ OH_Huks_Result HksDsaSignVerifyTestNormalCase(struct OH_Huks_Blob keyAlias, stru
*/
*/
HWTEST_F
(
HuksSignVerifyDSATest
,
Security_HUKS_NAPI_SignVerify_DSA_0100
,
TestSize
.
Level0
)
HWTEST_F
(
HuksSignVerifyDSATest
,
Security_HUKS_NAPI_SignVerify_DSA_0100
,
TestSize
.
Level0
)
{
{
const
char
*
keyAliasString
=
"HksDSASignVerifyKeyAliasTest001"
;
if
(
useSoftware
)
struct
OH_Huks_ParamSet
*
genParamSet
=
nullptr
;
{
struct
OH_Huks_ParamSet
*
signParamSet
=
nullptr
;
const
char
*
keyAliasString
=
"HksDSASignVerifyKeyAliasTest001"
;
struct
OH_Huks_ParamSet
*
verifyParamSet
=
nullptr
;
struct
OH_Huks_ParamSet
*
genParamSet
=
nullptr
;
struct
OH_Huks_Blob
keyAlias
=
{
strlen
(
keyAliasString
),
(
uint8_t
*
)
keyAliasString
};
struct
OH_Huks_ParamSet
*
signParamSet
=
nullptr
;
struct
OH_Huks_ParamSet
*
verifyParamSet
=
nullptr
;
OH_Huks_Result
ret
=
InitParamSet
(
&
genParamSet
,
g_genParamsTest001
,
sizeof
(
g_genParamsTest001
)
/
sizeof
(
OH_Huks_Param
));
struct
OH_Huks_Blob
keyAlias
=
{
strlen
(
keyAliasString
),
(
uint8_t
*
)
keyAliasString
};
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
ret
=
InitParamSet
(
&
signParamSet
,
g_signParamsTest001
,
sizeof
(
g_signParamsTest001
)
/
sizeof
(
OH_Huks_Param
));
OH_Huks_Result
ret
=
InitParamSet
(
&
genParamSet
,
g_genParamsTest001
,
sizeof
(
g_genParamsTest001
)
/
sizeof
(
OH_Huks_Param
));
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
ret
=
InitParamSet
(
&
verifyParamSet
,
g_verifyParamsTest001
,
sizeof
(
g_verifyParamsTest001
)
/
sizeof
(
OH_Huks_Param
));
ret
=
InitParamSet
(
&
signParamSet
,
g_signParamsTest001
,
sizeof
(
g_signParamsTest001
)
/
sizeof
(
OH_Huks_Param
));
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
if
((
genParamSet
!=
nullptr
)
||
(
signParamSet
!=
nullptr
)
||
(
verifyParamSet
!=
nullptr
))
{
ret
=
InitParamSet
(
&
verifyParamSet
,
g_verifyParamsTest001
,
sizeof
(
g_verifyParamsTest001
)
/
sizeof
(
OH_Huks_Param
));
ret
=
HksDsaSignVerifyTestNormalCase
(
keyAlias
,
genParamSet
,
signParamSet
,
verifyParamSet
);
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"InitParamSet failed."
;
if
((
genParamSet
!=
nullptr
)
||
(
signParamSet
!=
nullptr
)
||
(
verifyParamSet
!=
nullptr
))
{
ret
=
HksDsaSignVerifyTestNormalCase
(
keyAlias
,
genParamSet
,
signParamSet
,
verifyParamSet
);
}
/* 5. Delete Key */
ret
=
OH_Huks_DeleteKeyItem
(
&
keyAlias
,
genParamSet
);
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"DeleteKey failed."
;
OH_Huks_FreeParamSet
(
&
genParamSet
);
OH_Huks_FreeParamSet
(
&
signParamSet
);
OH_Huks_FreeParamSet
(
&
verifyParamSet
);
}
}
ASSERT_TRUE
(
0
==
0
);
/* 5. Delete Key */
ret
=
OH_Huks_DeleteKeyItem
(
&
keyAlias
,
genParamSet
);
EXPECT_EQ
(
ret
.
errorCode
,
(
int32_t
)
OH_HUKS_SUCCESS
)
<<
"DeleteKey failed."
;
OH_Huks_FreeParamSet
(
&
genParamSet
);
OH_Huks_FreeParamSet
(
&
signParamSet
);
OH_Huks_FreeParamSet
(
&
verifyParamSet
);
}
}
}
// namespace Unittest::DsaSignVerify
}
// namespace Unittest::DsaSignVerify
\ No newline at end of file
security/huks_napi_BasicTest/src/huks_three_stage_test_common.cpp
浏览文件 @
8bf51f86
...
@@ -15,6 +15,17 @@
...
@@ -15,6 +15,17 @@
#include "huks_three_stage_test_common.h"
#include "huks_three_stage_test_common.h"
static
struct
OH_Huks_Param
g_genParamsTest001
[]
=
{
{.
tag
=
OH_HUKS_TAG_ALGORITHM
,
.
uint32Param
=
OH_HUKS_ALG_DSA
},
{.
tag
=
OH_HUKS_TAG_PURPOSE
,
.
uint32Param
=
OH_HUKS_KEY_PURPOSE_SIGN
|
OH_HUKS_KEY_PURPOSE_VERIFY
},
{.
tag
=
OH_HUKS_TAG_KEY_SIZE
,
.
uint32Param
=
1024
},
{.
tag
=
OH_HUKS_TAG_DIGEST
,
.
uint32Param
=
OH_HUKS_DIGEST_SHA1
}
};
OH_Huks_Result
InitParamSet
(
OH_Huks_Result
InitParamSet
(
struct
OH_Huks_ParamSet
**
paramSet
,
struct
OH_Huks_ParamSet
**
paramSet
,
const
struct
OH_Huks_Param
*
params
,
const
struct
OH_Huks_Param
*
params
,
...
@@ -680,4 +691,19 @@ OH_Huks_Result HuksAgreeKey(const struct OH_Huks_ParamSet *paramSet, const struc
...
@@ -680,4 +691,19 @@ OH_Huks_Result HuksAgreeKey(const struct OH_Huks_ParamSet *paramSet, const struc
return
ret
;
return
ret
;
}
}
return
ret
;
return
ret
;
}
bool
checkUseSoftware
()
{
const
char
*
keyAliasString
=
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
;
struct
OH_Huks_ParamSet
*
genParamSet
=
nullptr
;
struct
OH_Huks_Blob
keyAlias
=
{
strlen
(
keyAliasString
),
(
uint8_t
*
)
keyAliasString
};
InitParamSet
(
&
genParamSet
,
g_genParamsTest001
,
sizeof
(
g_genParamsTest001
)
/
sizeof
(
OH_Huks_Param
));
OH_Huks_Result
ret
=
OH_Huks_GenerateKeyItem
(
&
keyAlias
,
genParamSet
,
nullptr
);
if
(
ret
.
errorCode
==
0
){
OH_Huks_DeleteKeyItem
(
&
keyAlias
,
genParamSet
);
OH_Huks_FreeParamSet
(
&
genParamSet
);
return
true
;
}
return
false
;
}
}
\ No newline at end of file
security/security_huks_basic/huks_hmac_callback_BasicTest/src/main/js/test/HMAC/SecurityHuksImportJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -788,20 +788,22 @@ export function SecurityHuksImportJsunit() {
...
@@ -788,20 +788,22 @@ export function SecurityHuksImportJsunit() {
it
(
'
HUKS_Basic_Capability_Import_2000
'
,
0
,
async
function
(
done
)
{
it
(
'
HUKS_Basic_Capability_Import_2000
'
,
0
,
async
function
(
done
)
{
const
srcKeyAlies
=
'
HUKS_Basic_Capability_Import_2000
'
;
const
srcKeyAlies
=
'
HUKS_Basic_Capability_Import_2000
'
;
let
HuksOptions
=
{
if
(
useSoftware
)
{
properties
:
new
Array
(
let
HuksOptions
=
{
HuksAgreeECDH
.
HuksKeyAlgECC
,
properties
:
new
Array
(
HuksAgreeECDH
.
HuksKeyPurposeECDH
,
HuksAgreeECDH
.
HuksKeyAlgECC
,
HuksAgreeECDH
.
HuksKeyECCSize224
,
HuksAgreeECDH
.
HuksKeyPurposeECDH
,
HuksAgreeECDH
.
HuksKeyECCDIGEST
,
HuksAgreeECDH
.
HuksKeyECCSize224
,
HuksAgreeECDH
.
HuksKeyECCPADDING
,
HuksAgreeECDH
.
HuksKeyECCDIGEST
,
HuksAgreeECDH
.
HuksKeyECCBLOCKMODE
,
HuksAgreeECDH
.
HuksKeyECCPADDING
,
{
tag
:
huks
.
HuksTag
.
HUKS_TAG_IMPORT_KEY_TYPE
,
value
:
huks
.
HuksImportKeyType
.
HUKS_KEY_TYPE_KEY_PAIR
}
HuksAgreeECDH
.
HuksKeyECCBLOCKMODE
,
),
{
tag
:
huks
.
HuksTag
.
HUKS_TAG_IMPORT_KEY_TYPE
,
value
:
huks
.
HuksImportKeyType
.
HUKS_KEY_TYPE_KEY_PAIR
}
inData
:
ecc224Key
,
),
};
inData
:
ecc224Key
,
await
publicImportKey
(
srcKeyAlies
,
HuksOptions
);
};
await
publicDeleteKeyFunc
(
srcKeyAlies
,
HuksOptions
);
await
publicImportKey
(
srcKeyAlies
,
HuksOptions
);
await
publicDeleteKeyFunc
(
srcKeyAlies
,
HuksOptions
);
}
done
();
done
();
});
});
...
...
security/security_huks_reformed_test/huks_hmac_callback_BasicTest/src/main/js/test/HMAC/SecurityHuksImportJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -1098,35 +1098,39 @@ export function SecurityHuksImportJsunit() {
...
@@ -1098,35 +1098,39 @@ export function SecurityHuksImportJsunit() {
it
(
'
HUKS_Basic_Capability_Import_Reformed_0300
'
,
0
,
async
function
(
done
)
{
it
(
'
HUKS_Basic_Capability_Import_Reformed_0300
'
,
0
,
async
function
(
done
)
{
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_0200
'
;
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_0200
'
;
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParams
,
false
);
if
(
useSoftware
)
{
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerEcdhParams
,
true
);
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParams
,
false
);
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerEcdhParams
,
true
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParams
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParams
);
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
importWrappedAes192Params
.
inData
=
wrappedData
;
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
await
publicImportWrappedKeyFunc
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192Params
);
importWrappedAes192Params
.
inData
=
wrappedData
;
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParams
);
await
publicImportWrappedKeyFunc
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192Params
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerEcdhParams
);
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParams
);
await
publicDeleteKeyItemFunc
(
importedKeyAliasAes192
,
importWrappedAes192Params
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerEcdhParams
);
await
publicDeleteKeyItemFunc
(
callerKekAliasAes256
,
callerAgreeParams
);
await
publicDeleteKeyItemFunc
(
importedKeyAliasAes192
,
importWrappedAes192Params
);
await
publicDeleteKeyItemFunc
(
callerKekAliasAes256
,
callerAgreeParams
);
}
done
();
done
();
});
});
it
(
'
HUKS_Basic_Capability_Import_Reformed_0400
'
,
0
,
async
function
(
done
)
{
it
(
'
HUKS_Basic_Capability_Import_Reformed_0400
'
,
0
,
async
function
(
done
)
{
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_0400
'
;
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_0400
'
;
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParamsX25519
,
false
);
if
(
useSoftware
)
{
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerX25519Params
,
true
);
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParamsX25519
,
false
);
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerX25519Params
,
true
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParamsX25519
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParamsX25519
);
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
importWrappedAes192ParamsX25519
.
inData
=
wrappedData
;
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
await
publicImportWrappedKeyFunc
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192ParamsX25519
);
importWrappedAes192ParamsX25519
.
inData
=
wrappedData
;
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParamsX25519
);
await
publicImportWrappedKeyFunc
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192ParamsX25519
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerX25519Params
);
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParamsX25519
);
await
publicDeleteKeyItemFunc
(
importedKeyAliasAes192
,
importWrappedAes192ParamsX25519
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerX25519Params
);
await
publicDeleteKeyItemFunc
(
callerKekAliasAes256
,
callerAgreeParams
);
await
publicDeleteKeyItemFunc
(
importedKeyAliasAes192
,
importWrappedAes192ParamsX25519
);
await
publicDeleteKeyItemFunc
(
callerKekAliasAes256
,
callerAgreeParams
);
}
done
();
done
();
});
});
...
@@ -1556,45 +1560,49 @@ export function SecurityHuksImportJsunit() {
...
@@ -1556,45 +1560,49 @@ export function SecurityHuksImportJsunit() {
it
(
'
HUKS_Basic_Capability_Import_Reformed_2600
'
,
0
,
async
function
(
done
)
{
it
(
'
HUKS_Basic_Capability_Import_Reformed_2600
'
,
0
,
async
function
(
done
)
{
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_0200
'
;
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_0200
'
;
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParams
,
false
);
if
(
useSoftware
)
{
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerEcdhParams
,
true
);
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParams
,
false
);
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerEcdhParams
,
true
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParams
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParams
);
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
importWrappedAes192Params
.
inData
=
wrappedData
;
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
await
publicImportWrappedKeyPromise
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192Params
);
importWrappedAes192Params
.
inData
=
wrappedData
;
await
publicImportWrappedKeyPromise
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192Params
);
await
publicImportWrappedKeyPromise
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192Params
);
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParams
);
await
publicImportWrappedKeyPromise
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192Params
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerEcdhParams
);
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParams
);
await
publicDeleteKeyItemFunc
(
importedKeyAliasAes192
,
importWrappedAes192Params
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerEcdhParams
);
await
publicDeleteKeyItemFunc
(
callerKekAliasAes256
,
callerAgreeParams
);
await
publicDeleteKeyItemFunc
(
importedKeyAliasAes192
,
importWrappedAes192Params
);
await
publicDeleteKeyItemFunc
(
callerKekAliasAes256
,
callerAgreeParams
);
}
done
();
done
();
});
});
it
(
'
HUKS_Basic_Capability_Import_Reformed_2700
'
,
0
,
async
function
(
done
)
{
it
(
'
HUKS_Basic_Capability_Import_Reformed_2700
'
,
0
,
async
function
(
done
)
{
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_2700
'
;
const
srcKeyAliesWrap
=
'
HUKS_Basic_Capability_Import_2700
'
;
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParams
,
false
);
if
(
useSoftware
)
{
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerEcdhParams
,
true
);
await
generateAndExportPublicKey
(
srcKeyAliesWrap
,
genWrappingKeyParams
,
false
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParams
);
await
generateAndExportPublicKey
(
callerKeyAlias
,
genCallerEcdhParams
,
true
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
await
ImportKekAndAgreeSharedSecret
(
callerKekAliasAes256
,
importParamsCallerKek
,
callerKeyAlias
,
huksPubKey
,
callerAgreeParams
);
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
await
EncryptImportedPlainKeyAndKek
(
importedAes192PlainKey
);
importWrappedAes192ParamsX25519
.
inData
=
wrappedData
;
let
wrappedData
=
await
BuildWrappedDataAndImportWrappedKey
(
importedAes192PlainKey
);
try
{
importWrappedAes192ParamsX25519
.
inData
=
wrappedData
;
await
importWrappedKeyItem
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192ParamsX25519
)
try
{
.
then
((
data
)
=>
{
await
importWrappedKeyItem
(
importedKeyAliasAes192
,
srcKeyAliesWrap
,
importWrappedAes192ParamsX25519
)
console
.
info
(
`callback: importWrappedKeyItem success, data =
${
JSON
.
stringify
(
data
)}
`
);
.
then
((
data
)
=>
{
})
console
.
info
(
`callback: importWrappedKeyItem success, data =
${
JSON
.
stringify
(
data
)}
`
);
.
catch
(
error
=>
{
})
console
.
error
(
`callback: importWrappedKeyItem failed, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
.
catch
(
error
=>
{
expect
(
error
.
code
==
12000006
).
assertTrue
();
console
.
error
(
`callback: importWrappedKeyItem failed, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
});
expect
(
error
.
code
==
12000006
).
assertTrue
();
}
catch
(
error
)
{
});
console
.
error
(
`callback: importWrappedKeyItem input arg invalid, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
}
catch
(
error
)
{
expect
(
null
).
assertFail
();
console
.
error
(
`callback: importWrappedKeyItem input arg invalid, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
expect
(
null
).
assertFail
();
}
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParams
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerEcdhParams
);
}
}
await
publicDeleteKeyItemFunc
(
srcKeyAliesWrap
,
genWrappingKeyParams
);
await
publicDeleteKeyItemFunc
(
callerKeyAlias
,
genCallerEcdhParams
);
done
();
done
();
});
});
...
...
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort63KBCallbackJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -23,7 +23,7 @@ let useSoftware = true;
...
@@ -23,7 +23,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicAbort63KBCallbackJsunit
()
{
export
default
function
SecurityHuksDSABasicAbort63KBCallbackJsunit
()
{
describe
(
'
SecurityHuksDSABasicAbort63KBCallbackJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicAbort63KBCallbackJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA002
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA002
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort65KBCallbackJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -24,7 +24,7 @@ let useSoftware = true;
...
@@ -24,7 +24,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicAbort65KBCallbackJsunit
()
{
export
default
function
SecurityHuksDSABasicAbort65KBCallbackJsunit
()
{
describe
(
'
SecurityHuksDSABasicAbort65KBCallbackJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicAbort65KBCallbackJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA004
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA004
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish63KBCallbackJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -24,7 +24,7 @@ let useSoftware = true;
...
@@ -24,7 +24,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicFinish63KBCallbackJsunit
()
{
export
default
function
SecurityHuksDSABasicFinish63KBCallbackJsunit
()
{
describe
(
'
SecurityHuksDSABasicFinish63KBCallbackJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicFinish63KBCallbackJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA001
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA001
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_callback_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish65KBCallbackJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -24,7 +24,7 @@ let useSoftware = true;
...
@@ -24,7 +24,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicFinish65KBCallbackJsunit
()
{
export
default
function
SecurityHuksDSABasicFinish65KBCallbackJsunit
()
{
describe
(
'
SecurityHuksDSABasicFinish65KBCallbackJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicFinish65KBCallbackJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA003
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA003
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort63KBPromiseJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -23,7 +23,7 @@ let useSoftware = true;
...
@@ -23,7 +23,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicAbort63KBPromiseJsunit
()
{
export
default
function
SecurityHuksDSABasicAbort63KBPromiseJsunit
()
{
describe
(
'
SecurityHuksDSABasicAbort63KBPromiseJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicAbort63KBPromiseJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA102
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA102
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicAbort65KBPromiseJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -15,7 +15,7 @@
...
@@ -15,7 +15,7 @@
import
{
describe
,
it
,
beforeAll
}
from
'
@ohos/hypium
'
;
import
{
describe
,
it
,
beforeAll
}
from
'
@ohos/hypium
'
;
import
Data
from
'
../../../../../../utils/data.json
'
;
import
Data
from
'
../../../../../../utils/data.json
'
;
import
{
HuksSignVerifyDSA
}
from
'
../../../../../../utils/param/signverify/publicSignverifyParam
'
;
import
{
HuksSignVerifyDSA
}
from
'
../../../../../../utils/param/signverify/publicSignverifyParam
'
;
import
{
stringToUint8Array
,
checkSoftware
}
from
'
../../../../../../utils/param/publicFunc
'
;
import
{
stringToUint8Array
,
checkSoftware
}
from
'
../../../../../../utils/param/publicFunc
'
;
import
{
publicSignVerifyFunc
}
from
'
../../../../../../utils/param/signverify/publicSignverifyPromise.js
'
;
import
{
publicSignVerifyFunc
}
from
'
../../../../../../utils/param/signverify/publicSignverifyPromise.js
'
;
let
srcData65
=
Data
.
Data65b
;
let
srcData65
=
Data
.
Data65b
;
let
srcData65Kb
=
stringToUint8Array
(
srcData65
);
let
srcData65Kb
=
stringToUint8Array
(
srcData65
);
...
@@ -23,7 +23,7 @@ let useSoftware = true;
...
@@ -23,7 +23,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicAbort65KBPromiseJsunit
()
{
export
default
function
SecurityHuksDSABasicAbort65KBPromiseJsunit
()
{
describe
(
'
SecurityHuksDSABasicAbort65KBPromiseJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicAbort65KBPromiseJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA104
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA104
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish63KBPromiseJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -24,7 +24,7 @@ let useSoftware = true;
...
@@ -24,7 +24,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicFinish63KBPromiseJsunit
()
{
export
default
function
SecurityHuksDSABasicFinish63KBPromiseJsunit
()
{
describe
(
'
SecurityHuksDSABasicFinish63KBPromiseJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicFinish63KBPromiseJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA101
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA101
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksDSABasicFinish65KBPromiseJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -24,7 +24,7 @@ let useSoftware = true;
...
@@ -24,7 +24,7 @@ let useSoftware = true;
export
default
function
SecurityHuksDSABasicFinish65KBPromiseJsunit
()
{
export
default
function
SecurityHuksDSABasicFinish65KBPromiseJsunit
()
{
describe
(
'
SecurityHuksDSABasicFinish65KBPromiseJsunit
'
,
function
()
{
describe
(
'
SecurityHuksDSABasicFinish65KBPromiseJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
checkSoftware
();
useSoftware
=
await
checkSoftware
();
done
();
done
();
})
})
it
(
'
testReformedSignVerifyDSA103
'
,
0
,
async
function
(
done
)
{
it
(
'
testReformedSignVerifyDSA103
'
,
0
,
async
function
(
done
)
{
...
...
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksECCBasicFinish65KBPromiseJsunit.test.js
浏览文件 @
8bf51f86
此差异已折叠。
点击以展开。
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksRSABasicFinish65KBPromiseJsunit.test.js
浏览文件 @
8bf51f86
此差异已折叠。
点击以展开。
security/security_huks_reformed_test/huks_signverify_promise_BasicTest/src/main/js/test/SignVerify/SecurityHuksRSASignExtendJsunit.test.js
浏览文件 @
8bf51f86
...
@@ -13,9 +13,9 @@
...
@@ -13,9 +13,9 @@
* limitations under the License.
* limitations under the License.
*/
*/
import
huks
from
"
@ohos.security.huks
"
;
import
huks
from
"
@ohos.security.huks
"
;
import
{
describe
,
it
,
expect
}
from
"
@ohos/hypium
"
;
import
{
describe
,
it
,
expect
,
beforeAll
}
from
"
@ohos/hypium
"
;
import
Data
from
'
../../../../../../utils/data.json
'
;
import
Data
from
'
../../../../../../utils/data.json
'
;
import
{
stringToUint8Array
}
from
'
../../../../../../utils/param/publicFunc
'
;
import
{
stringToUint8Array
,
checkSoftware
}
from
'
../../../../../../utils/param/publicFunc
'
;
import
{
HuksSignVerifyRSA
}
from
'
../../../../../../utils/param/signverify/publicSignverifyParam
'
;
import
{
HuksSignVerifyRSA
}
from
'
../../../../../../utils/param/signverify/publicSignverifyParam
'
;
let
inDataString
=
"
Hks_RSA_Sign_Verify_Test_0000000000000000000000000000000000000000000000000000000
"
+
let
inDataString
=
"
Hks_RSA_Sign_Verify_Test_0000000000000000000000000000000000000000000000000000000
"
+
...
@@ -29,6 +29,7 @@ let srcData64 = Data.Data64b;
...
@@ -29,6 +29,7 @@ let srcData64 = Data.Data64b;
let
srcData64Kb
=
stringToUint8Array
(
srcData64
);
let
srcData64Kb
=
stringToUint8Array
(
srcData64
);
let
signedResult
;
let
signedResult
;
let
handle
;
let
handle
;
let
useSoftware
=
true
;
async
function
publicGenerateKeyFunc
(
srcKeyAlias
,
genHuksOptionsNONECBC
)
{
async
function
publicGenerateKeyFunc
(
srcKeyAlias
,
genHuksOptionsNONECBC
)
{
console
.
error
(
`enter promise generateKeyItem`
);
console
.
error
(
`enter promise generateKeyItem`
);
...
@@ -91,7 +92,7 @@ async function publicUpdateSessionFunction(HuksOptions) {
...
@@ -91,7 +92,7 @@ async function publicUpdateSessionFunction(HuksOptions) {
let
isFinished
=
false
;
let
isFinished
=
false
;
let
outData
=
[];
let
outData
=
[];
while
(
inDataSegPosition
<=
lastInDataPosition
)
{
while
(
inDataSegPosition
<=
lastInDataPosition
)
{
HuksOptions
.
inData
=
new
Uint8Array
(
HuksOptions
.
inData
=
new
Uint8Array
(
Array
.
from
(
inData
).
slice
(
inDataSegPosition
,
inDataSegPosition
+
inDataSegSize
)
Array
.
from
(
inData
).
slice
(
inDataSegPosition
,
inDataSegPosition
+
inDataSegSize
)
);
);
...
@@ -127,22 +128,22 @@ async function publicUpdateSessionFunction(HuksOptions) {
...
@@ -127,22 +128,22 @@ async function publicUpdateSessionFunction(HuksOptions) {
}
}
}
}
async
function
publicUpdateError
(
HuksOptions
,
errCode
){
async
function
publicUpdateError
(
HuksOptions
,
errCode
)
{
console
.
error
(
`enter promise doUpdate`
);
console
.
error
(
`enter promise doUpdate`
);
try
{
try
{
await
huks
.
updateSession
(
handle
,
HuksOptions
)
await
huks
.
updateSession
(
handle
,
HuksOptions
)
.
then
((
data
)
=>
{
.
then
((
data
)
=>
{
console
.
error
(
`promise: doUpdate success, data =
${
JSON
.
stringify
(
data
)}
`
);
console
.
error
(
`promise: doUpdate success, data =
${
JSON
.
stringify
(
data
)}
`
);
expect
(
null
).
assertFail
();
expect
(
null
).
assertFail
();
})
})
.
catch
(
error
=>
{
.
catch
(
error
=>
{
console
.
error
(
`promise: doUpdate failed, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
console
.
error
(
`promise: doUpdate failed, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
expect
(
err
.
code
==
errCode
).
assertTrue
();
expect
(
err
.
code
==
errCode
).
assertTrue
();
});
});
}
catch
(
error
)
{
}
catch
(
error
)
{
console
.
error
(
`promise: doUpdate input arg invalid, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
console
.
error
(
`promise: doUpdate input arg invalid, code:
${
error
.
code
}
, msg:
${
error
.
message
}
`
);
expect
(
null
).
assertFail
();
expect
(
null
).
assertFail
();
}
}
}
}
async
function
publicFinishSessionFunc
(
HuksOptions
)
{
async
function
publicFinishSessionFunc
(
HuksOptions
)
{
...
@@ -184,7 +185,10 @@ async function publicDeleteKeyFunc(srcKeyAlias, genHuksOptionsNONECBC) {
...
@@ -184,7 +185,10 @@ async function publicDeleteKeyFunc(srcKeyAlias, genHuksOptionsNONECBC) {
export
default
function
SecurityHuksRSASignExtendJsunit
()
{
export
default
function
SecurityHuksRSASignExtendJsunit
()
{
describe
(
'
SecurityHuksRSASignExtendJsunit
'
,
function
()
{
describe
(
'
SecurityHuksRSASignExtendJsunit
'
,
function
()
{
beforeAll
(
async
function
(
done
)
{
useSoftware
=
await
checkSoftware
();
done
();
})
/**
/**
* @tc.number Security_HUKS_RSA_SignExtend_0100
* @tc.number Security_HUKS_RSA_SignExtend_0100
* @tc.name No Padding and Sign Verify with RSA.
* @tc.name No Padding and Sign Verify with RSA.
...
@@ -192,48 +196,50 @@ export default function SecurityHuksRSASignExtendJsunit() {
...
@@ -192,48 +196,50 @@ export default function SecurityHuksRSASignExtendJsunit() {
*/
*/
it
(
"
Security_HUKS_RSA_SignExtend_0100
"
,
0
,
async
function
(
done
)
{
it
(
"
Security_HUKS_RSA_SignExtend_0100
"
,
0
,
async
function
(
done
)
{
let
srcKeyAliesGen
=
"
Security_HUKS_RSA_SignExtend_0100_Gen
"
;
let
srcKeyAliesGen
=
"
Security_HUKS_RSA_SignExtend_0100_Gen
"
;
let
HuksOptionsGen
=
{
if
(
useSoftware
)
{
properties
:
new
Array
(
let
HuksOptionsGen
=
{
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
properties
:
new
Array
(
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSINGVERIFY
,
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSINGVERIFY
,
HuksSignVerifyRSA
.
HuksKeyRSASize4096
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
),
HuksSignVerifyRSA
.
HuksKeyRSASize4096
inData
:
srcData64Kb
,
),
};
inData
:
srcData64Kb
,
let
HuksOptionsSign
=
{
};
properties
:
new
Array
(
let
HuksOptionsSign
=
{
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
properties
:
new
Array
(
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSIGN
,
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSIGN
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSASize4096
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
),
HuksSignVerifyRSA
.
HuksKeyRSASize4096
inData
:
srcData64Kb
,
),
}
inData
:
srcData64Kb
,
await
publicGenerateKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsSign
);
await
publicGenerateKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
HuksOptionsSign
.
inData
=
srcData64Kb
;
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsSign
);
await
publicUpdateSessionFunction
(
HuksOptionsSign
);
HuksOptionsSign
.
inData
=
srcData64Kb
;
HuksOptionsSign
.
inData
=
new
Uint8Array
(
new
Array
());
await
publicUpdateSessionFunction
(
HuksOptionsSign
);
await
publicFinishSessionFunc
(
HuksOptionsSign
);
HuksOptionsSign
.
inData
=
new
Uint8Array
(
new
Array
());
await
publicFinishSessionFunc
(
HuksOptionsSign
);
let
HuksOptionsVerify
=
{
let
HuksOptionsVerify
=
{
properties
:
new
Array
(
properties
:
new
Array
(
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeVERIFY
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeVERIFY
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksKeyRSASize4096
HuksSignVerifyRSA
.
HuksKeyRSASize4096
),
),
inData
:
srcData64Kb
,
inData
:
srcData64Kb
,
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
srcData64Kb
;
publicUpdateSessionFunction
(
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
signedResult
;
await
publicFinishSessionFunc
(
HuksOptionsVerify
);
await
publicDeleteKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
}
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
srcData64Kb
;
publicUpdateSessionFunction
(
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
signedResult
;
await
publicFinishSessionFunc
(
HuksOptionsVerify
);
await
publicDeleteKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
done
();
done
();
})
})
...
@@ -244,48 +250,50 @@ export default function SecurityHuksRSASignExtendJsunit() {
...
@@ -244,48 +250,50 @@ export default function SecurityHuksRSASignExtendJsunit() {
*/
*/
it
(
"
Security_HUKS_RSA_SignExtend_0200
"
,
0
,
async
function
(
done
)
{
it
(
"
Security_HUKS_RSA_SignExtend_0200
"
,
0
,
async
function
(
done
)
{
let
srcKeyAliesGen
=
"
Security_HUKS_RSA_SignExtend_0200
"
;
let
srcKeyAliesGen
=
"
Security_HUKS_RSA_SignExtend_0200
"
;
let
HuksOptionsGen
=
{
if
(
useSoftware
)
{
properties
:
new
Array
(
let
HuksOptionsGen
=
{
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
properties
:
new
Array
(
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSINGVERIFY
,
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSINGVERIFY
,
HuksSignVerifyRSA
.
HuksKeyRSASize4096
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
),
HuksSignVerifyRSA
.
HuksKeyRSASize4096
inData
:
srcData64Kb
,
),
};
inData
:
srcData64Kb
,
let
HuksOptionsSign
=
{
};
properties
:
new
Array
(
let
HuksOptionsSign
=
{
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
properties
:
new
Array
(
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSIGN
,
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeSIGN
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSASize4096
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
),
HuksSignVerifyRSA
.
HuksKeyRSASize4096
inData
:
srcData64Kb
,
),
}
inData
:
srcData64Kb
,
await
publicGenerateKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsSign
);
await
publicGenerateKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
HuksOptionsSign
.
inData
=
srcData64Kb
;
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsSign
);
await
publicUpdateSessionFunction
(
HuksOptionsSign
);
HuksOptionsSign
.
inData
=
srcData64Kb
;
HuksOptionsSign
.
inData
=
new
Uint8Array
(
new
Array
());
await
publicUpdateSessionFunction
(
HuksOptionsSign
);
await
publicFinishSessionFunc
(
HuksOptionsSign
);
HuksOptionsSign
.
inData
=
new
Uint8Array
(
new
Array
());
await
publicFinishSessionFunc
(
HuksOptionsSign
);
let
HuksOptionsVerify
=
{
let
HuksOptionsVerify
=
{
properties
:
new
Array
(
properties
:
new
Array
(
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeVERIFY
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeVERIFY
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksKeyRSASize4096
HuksSignVerifyRSA
.
HuksKeyRSASize4096
),
),
inData
:
srcData64Kb
,
inData
:
srcData64Kb
,
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
srcData64Kb
;
publicUpdateSessionFunction
(
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
signedResult
;
await
publicFinishSessionFunc
(
HuksOptionsVerify
);
await
publicDeleteKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
}
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
srcData64Kb
;
publicUpdateSessionFunction
(
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
signedResult
;
await
publicFinishSessionFunc
(
HuksOptionsVerify
);
await
publicDeleteKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
done
();
done
();
})
})
...
@@ -314,29 +322,31 @@ export default function SecurityHuksRSASignExtendJsunit() {
...
@@ -314,29 +322,31 @@ export default function SecurityHuksRSASignExtendJsunit() {
),
),
inData
:
srcData64Kb
,
inData
:
srcData64Kb
,
}
}
await
publicGenerateKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
if
(
useSoftware
)
{
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsSign
);
await
publicGenerateKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
HuksOptionsSign
.
inData
=
srcData64Kb
;
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsSign
);
await
publicUpdateSessionFunction
(
HuksOptionsSign
);
HuksOptionsSign
.
inData
=
srcData64Kb
;
HuksOptionsSign
.
inData
=
new
Uint8Array
(
new
Array
());
await
publicUpdateSessionFunction
(
HuksOptionsSign
);
await
publicFinishSessionFunc
(
HuksOptionsSign
);
HuksOptionsSign
.
inData
=
new
Uint8Array
(
new
Array
());
await
publicFinishSessionFunc
(
HuksOptionsSign
);
let
HuksOptionsVerify
=
{
let
HuksOptionsVerify
=
{
properties
:
new
Array
(
properties
:
new
Array
(
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksKeyAlgRSA
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeVERIFY
,
HuksSignVerifyRSA
.
HuksKeyRSAPurposeVERIFY
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksTagPKCS1DigestSHA256
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksKeyRSAPADDINGPKCS1V15
,
HuksSignVerifyRSA
.
HuksKeyRSASize4096
HuksSignVerifyRSA
.
HuksKeyRSASize4096
),
),
inData
:
srcData64Kb
,
inData
:
srcData64Kb
,
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
srcData64Kb
;
publicUpdateSessionFunction
(
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
signedResult
;
await
publicFinishSessionFunc
(
HuksOptionsVerify
);
await
publicDeleteKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
}
}
await
publicInitFunc
(
srcKeyAliesGen
,
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
srcData64Kb
;
publicUpdateSessionFunction
(
HuksOptionsVerify
);
HuksOptionsVerify
.
inData
=
signedResult
;
await
publicFinishSessionFunc
(
HuksOptionsVerify
);
await
publicDeleteKeyFunc
(
srcKeyAliesGen
,
HuksOptionsGen
);
done
();
done
();
})
})
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录