獲取密鑰屬性(C/C++)
HUKS提供了接口供業(yè)務(wù)獲取指定密鑰的相關(guān)屬性。在獲取指定密鑰屬性前,需要確保已在HUKS中生成或?qū)氤志没鎯Φ拿荑€。
開發(fā)前請熟悉鴻蒙開發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md
]
在CMake腳本中鏈接相關(guān)動態(tài)庫
target_link_libraries(entry PUBLIC libhuks_ndk.z.so)
開發(fā)步驟
- 構(gòu)造對應(yīng)參數(shù)。
- 調(diào)用接口[OH_Huks_GetKeyItemParamSet],傳入上述參數(shù)。
- 返回值為成功碼/錯誤碼,獲取成功后,從參數(shù)集中讀取需要的參數(shù)。
`HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿`
#include "huks/native_huks_api.h"
#include "huks/native_huks_param.h"
#include < string.h >
static napi_value GetKeyParamSet(napi_env env, napi_callback_info info)
{
/* 1. 參數(shù)構(gòu)造:確定密鑰別名 */
const char *alias = "test_key";
struct OH_Huks_Blob aliasBlob = { .size = (uint32_t)strlen(alias), .data = (uint8_t *)alias };
/* 構(gòu)造參數(shù):為參數(shù)集申請內(nèi)存 */
struct OH_Huks_ParamSet *outParamSet = (struct OH_Huks_ParamSet *)malloc(512); // 請業(yè)務(wù)按實際情況評估大小進行申請
if (outParamSet == nullptr) {
return nullptr;
}
outParamSet- >paramSetSize = 512;
struct OH_Huks_Result ohResult;
do {
/* 2. 獲取密鑰屬性集 */
ohResult = OH_Huks_GetKeyItemParamSet(&aliasBlob, nullptr, outParamSet);
if (ohResult.errorCode != OH_HUKS_SUCCESS) {
break;
}
/* 3. 從參數(shù)集中讀取參數(shù),以O(shè)H_HUKS_TAG_PURPOSE為例 */
OH_Huks_Param *purposeParam = nullptr; // 無需申請內(nèi)存,獲取后指針指向該參數(shù)在參數(shù)集中所處內(nèi)存地址
ohResult = OH_Huks_GetParam(outParamSet, OH_HUKS_TAG_PURPOSE, &purposeParam);
if (ohResult.errorCode != OH_HUKS_SUCCESS) {
break;
}
} while (0);
OH_Huks_FreeParamSet(&outParamSet);
napi_value ret;
napi_create_int32(env, ohResult.errorCode, &ret);
return ret;
}
審核編輯 黃宇
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
C++
+關(guān)注
關(guān)注
22文章
2114瀏覽量
73856 -
鴻蒙
+關(guān)注
關(guān)注
57文章
2392瀏覽量
43050
發(fā)布評論請先 登錄
相關(guān)推薦
鴻蒙開發(fā):Universal Keystore Kit密鑰管理服務(wù)簡介
Universal Keystore Kit(密鑰管理服務(wù),下述簡稱為HUKS)向業(yè)務(wù)/應(yīng)用提供
鴻蒙開發(fā):Universal Keystore Kit密鑰管理服務(wù) 密鑰導(dǎo)入介紹及算法規(guī)格
如果業(yè)務(wù)在HUKS外部生成密鑰(比如應(yīng)用間協(xié)商生成、服務(wù)器端生成),業(yè)務(wù)可以將密鑰導(dǎo)入到HUKS中由HUKS進行管理。密鑰一旦導(dǎo)入到HUKS
鴻蒙開發(fā):Universal Keystore Kit密鑰管理服務(wù) 加密導(dǎo)入密鑰C、C++
以加密導(dǎo)入ECDH密鑰對為例,涉及業(yè)務(wù)側(cè)加密密鑰的[密鑰生成]、[協(xié)商]等操作不在本示例中體現(xiàn)。
鴻蒙開發(fā):Universal Keystore Kit 密鑰管理服務(wù) 密鑰協(xié)商ArkTS
以協(xié)商密鑰類型為X25519 256,并密鑰僅在HUKS內(nèi)使用為例,完成密鑰協(xié)商。
鴻蒙開發(fā):Universal Keystore Kit 密鑰管理服務(wù) 密鑰協(xié)商 C、C++
以協(xié)商密鑰類型為ECDH,并密鑰僅在HUKS內(nèi)使用為例,完成密鑰協(xié)商。具體的場景介紹及支持的算法規(guī)格,請參考[密鑰生成支持的算法]。
鴻蒙開發(fā):Universal Keystore Kit密鑰管理服務(wù) 密鑰派生C、C++
以HKDF256密鑰為例,完成密鑰派生。具體的場景介紹及支持的算法規(guī)格,請參考[密鑰生成支持的算法]。
鴻蒙開發(fā):Universal Keystore Kit 密鑰管理服務(wù) HMAC ArkTS
HMAC是密鑰相關(guān)的哈希運算消息認證碼(Hash-based Message Authentication Code),是一種基于Hash函數(shù)和密鑰進行消息認證的方法。
鴻蒙開發(fā):Universal Keystore Kit 密鑰管理服務(wù) HMAC C、C++
HMAC是密鑰相關(guān)的哈希運算消息認證碼(Hash-based Message Authentication Code),是一種基于Hash函數(shù)和密鑰進行消息認證的方法。
鴻蒙開發(fā):Universal Keystore Kit密鑰管理服務(wù) 密鑰刪除C C++
為保證數(shù)據(jù)安全性,當(dāng)不需要使用該密鑰時,應(yīng)該刪除密鑰。
鴻蒙開發(fā):Universal Keystore Kit密鑰管理服務(wù) 查詢密鑰是否存在C、C++
HUKS提供了接口供應(yīng)用查詢指定密鑰是否存在。
鴻蒙開發(fā):Universal Keystore Kit密鑰管理服務(wù) 查詢密鑰是否存在C C++
HUKS提供了接口供應(yīng)用查詢指定密鑰是否存在。
鴻蒙開發(fā):Universal Keystore Kit 密鑰管理服務(wù) 獲取密鑰屬性ArkTS
HUKS提供了接口供業(yè)務(wù)獲取指定密鑰的相關(guān)屬性。在獲取指定密鑰屬性前,需要確保已在HUKS中生成
鴻蒙開發(fā):Universal Keystore Kit 密鑰管理服務(wù) 密鑰導(dǎo)出 C C++
業(yè)務(wù)需要獲取持久化存儲的非對稱密鑰的公鑰時使用,當(dāng)前支持ECC/RSA/ED25519/X25519的公鑰導(dǎo)出。
評論