# ç¾å/验ç¾(C/C++) 以密钥算法为RSA2048ã€æ‘˜è¦ç®—法为SHA384ã€å¡«å……模å¼ä¸ºPSS的密钥为例,完æˆç¾åã€éªŒç¾ã€‚具体的场景介ç»åŠæ”¯æŒçš„ç®—æ³•è§„æ ¼ï¼Œè¯·å‚考[ç¾å/éªŒç¾æ”¯æŒçš„算法](huks-signing-signature-verification-overview.md#支æŒçš„算法)。 ## 在CMake脚本ä¸é“¾æŽ¥ç›¸å…³åЍæ€åº“ ```txt target_link_libraries(entry PUBLIC libhuks_ndk.z.so) ``` ## 开呿¥éª¤ **生æˆå¯†é’¥** 1. 指定密钥别å。 2. åˆå§‹åŒ–密钥属性集。 3. 调用OH_Huks_GenerateKeyItem生æˆå¯†é’¥ï¼Œå…·ä½“请å‚考[密钥生æˆ](huks-key-generation-overview.md)。 除æ¤ä¹‹å¤–,开å‘者也å¯ä»¥å‚考[密钥导入](huks-key-import-overview.md),导入已有的密钥。 **ç¾å** 1. 获å–密钥别å。 2. 指定待ç¾å的明文数æ®ã€‚ 3. 调用[OH_Huks_InitParamSet](../../reference/apis-universal-keystore-kit/_huks_param_set_api.md#oh_huks_initparamset)æŒ‡å®šç®—æ³•å‚æ•°é…置。 4. 调用[OH_Huks_InitSession](../../reference/apis-universal-keystore-kit/_huks_key_api.md#oh_huks_initsession)åˆå§‹åŒ–密钥会è¯ï¼Œå¹¶èŽ·å–会è¯çš„奿Ÿ„handle。 5. 调用[OH_Huks_FinishSession](../../reference/apis-universal-keystore-kit/_huks_key_api.md#oh_huks_finishsession)结æŸå¯†é’¥ä¼šè¯ï¼ŒèŽ·å–ç¾åsignature。 **验ç¾** 1. 获å–密钥别å。 2. 获å–待验è¯çš„ç¾åsignature。 3. 指定[ç®—æ³•å‚æ•°é…ç½®](../../reference/apis-universal-keystore-kit/_huks_param_set_api.md#oh_huks_initparamset)。 4. 调用[OH_Huks_InitSession](../../reference/apis-universal-keystore-kit/_huks_key_api.md#oh_huks_initsession)åˆå§‹åŒ–密钥会è¯ï¼Œå¹¶èŽ·å–会è¯çš„奿Ÿ„handle。 5. 调用[OH_Huks_UpdateSession](../../reference/apis-universal-keystore-kit/_huks_key_api.md#oh_huks_updatesession)更新密钥会è¯ã€‚ 6. 调用[OH_Huks_FinishSession](../../reference/apis-universal-keystore-kit/_huks_key_api.md#oh_huks_finishsession)结æŸå¯†é’¥ä¼šè¯ï¼ŒéªŒè¯ç¾å。 **åˆ é™¤å¯†é’¥** 当密钥废弃ä¸ç”¨æ—¶ï¼Œéœ€è¦è°ƒç”¨OH_Huks_DeleteKeyItemåˆ é™¤å¯†é’¥ï¼Œå…·ä½“è¯·å‚考[å¯†é’¥åˆ é™¤](huks-delete-key-ndk.md)。 ```c++ #include "huks/native_huks_api.h" #include "huks/native_huks_param.h" #include <string.h> OH_Huks_Result InitParamSet( struct OH_Huks_ParamSet **paramSet, const struct OH_Huks_Param *params, uint32_t paramCount) { OH_Huks_Result ret = OH_Huks_InitParamSet(paramSet); if (ret.errorCode != OH_HUKS_SUCCESS) { return ret; } ret = OH_Huks_AddParams(*paramSet, params, paramCount); if (ret.errorCode != OH_HUKS_SUCCESS) { OH_Huks_FreeParamSet(paramSet); return ret; } ret = OH_Huks_BuildParamSet(paramSet); if (ret.errorCode != OH_HUKS_SUCCESS) { OH_Huks_FreeParamSet(paramSet); return ret; } return ret; } static struct OH_Huks_Param g_genSignVerifyParamsTest[] = { { .tag = OH_HUKS_TAG_ALGORITHM, .uint32Param = OH_HUKS_ALG_RSA }, { .tag = OH_HUKS_TAG_PURPOSE, .uint32Param = OH_HUKS_KEY_PURPOSE_SIGN | OH_HUKS_KEY_PURPOSE_VERIFY }, { .tag = OH_HUKS_TAG_KEY_SIZE, .uint32Param = OH_HUKS_RSA_KEY_SIZE_2048 }, { .tag = OH_HUKS_TAG_PADDING, .uint32Param = OH_HUKS_PADDING_PSS }, { .tag = OH_HUKS_TAG_DIGEST, .uint32Param = OH_HUKS_DIGEST_SHA384 }, }; static struct OH_Huks_Param g_signParamsTest[] = { { .tag = OH_HUKS_TAG_ALGORITHM, .uint32Param = OH_HUKS_ALG_RSA }, { .tag = OH_HUKS_TAG_PURPOSE, .uint32Param = OH_HUKS_KEY_PURPOSE_SIGN }, { .tag = OH_HUKS_TAG_KEY_SIZE, .uint32Param = OH_HUKS_RSA_KEY_SIZE_2048 }, { .tag = OH_HUKS_TAG_PADDING, .uint32Param = OH_HUKS_PADDING_PSS }, { .tag = OH_HUKS_TAG_DIGEST, .uint32Param = OH_HUKS_DIGEST_SHA384 } }; static struct OH_Huks_Param g_verifyParamsTest[] = { { .tag = OH_HUKS_TAG_ALGORITHM, .uint32Param = OH_HUKS_ALG_RSA }, { .tag = OH_HUKS_TAG_PURPOSE, .uint32Param = OH_HUKS_KEY_PURPOSE_VERIFY }, { .tag = OH_HUKS_TAG_KEY_SIZE, .uint32Param = OH_HUKS_RSA_KEY_SIZE_2048 }, { .tag = OH_HUKS_TAG_PADDING, .uint32Param = OH_HUKS_PADDING_PSS }, { .tag = OH_HUKS_TAG_DIGEST, .uint32Param = OH_HUKS_DIGEST_SHA384 } }; static const uint32_t RSA_COMMON_SIZE = 1024; static const char *g_dataToSign = "Hks_RSA_Sign_Verify_Test_0000000000000000000000000000000000000000000000000000000" "00000000000000000000000000000000000000000000000000000000000000000000000000000000" "0000000000000000000000000000000000000000000000000000000000000000000000000_string"; static napi_value SignVerifyKey(napi_env env, napi_callback_info info) { struct OH_Huks_Blob g_keyAlias = { (uint32_t)strlen("test_signVerify"), (uint8_t *)"test_signVerify" }; struct OH_Huks_Blob inData = { (uint32_t)strlen(g_dataToSign), (uint8_t *)g_dataToSign }; struct OH_Huks_ParamSet *genParamSet = nullptr; struct OH_Huks_ParamSet *signParamSet = nullptr; struct OH_Huks_ParamSet *verifyParamSet = nullptr; OH_Huks_Result ohResult; do { ohResult = InitParamSet(&genParamSet, g_genSignVerifyParamsTest, sizeof(g_genSignVerifyParamsTest) / sizeof(OH_Huks_Param)); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } ohResult = InitParamSet(&signParamSet, g_signParamsTest, sizeof(g_signParamsTest) / sizeof(OH_Huks_Param)); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } ohResult = InitParamSet(&verifyParamSet, g_verifyParamsTest, sizeof(g_verifyParamsTest) / sizeof(OH_Huks_Param)); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } /* 1. Generate Key */ ohResult = OH_Huks_GenerateKeyItem(&g_keyAlias, genParamSet, nullptr); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } /* 2. Sign */ // Init uint8_t handleS[sizeof(uint64_t)] = {0}; struct OH_Huks_Blob handleSign = { (uint32_t)sizeof(uint64_t), handleS }; ohResult = OH_Huks_InitSession(&g_keyAlias, signParamSet, &handleSign, nullptr); // Update uint8_t outDataS[RSA_COMMON_SIZE] = {0}; struct OH_Huks_Blob outDataSign = { RSA_COMMON_SIZE, outDataS }; ohResult = OH_Huks_UpdateSession(&handleSign, signParamSet, &inData, &outDataSign); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } // Finish struct OH_Huks_Blob finishInData = { 0, NULL }; ohResult = OH_Huks_FinishSession(&handleSign, signParamSet, &finishInData, &outDataSign); /* 3. Verify */ // Init uint8_t handleV[sizeof(uint64_t)] = {0}; struct OH_Huks_Blob handleVerify = { (uint32_t)sizeof(uint64_t), handleV }; ohResult = OH_Huks_InitSession(&g_keyAlias, verifyParamSet, &handleVerify, nullptr); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } // Update loop uint8_t temp[] = "out"; struct OH_Huks_Blob verifyOut = { (uint32_t)sizeof(temp), temp }; ohResult = OH_Huks_UpdateSession(&handleVerify, verifyParamSet, &inData, &verifyOut); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } // Finish ohResult = OH_Huks_FinishSession(&handleVerify, verifyParamSet, &outDataSign, &verifyOut); if (ohResult.errorCode != OH_HUKS_SUCCESS) { break; } } while (0); (void)OH_Huks_DeleteKeyItem(&g_keyAlias, genParamSet); OH_Huks_FreeParamSet(&genParamSet); OH_Huks_FreeParamSet(&signParamSet); OH_Huks_FreeParamSet(&verifyParamSet); napi_value ret; napi_create_int32(env, ohResult.errorCode, &ret); return ret; } ```