加解密问题的定位指导

密钥对在HarmonyOS侧导入失败。

HarmonyOS
2024-09-18 12:32:40
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
zbw_apple

方案:不能直接拿到HarmonyOS侧使用,需要进行编码转换后使用。

根据密钥参数生成sm2私钥:

import { cryptoFramework } from '@kit.CryptoArchitectureKit' 
 
export async function convertStrToPriKey(keyStr: string): Promise<cryptoFramework.PriKey> { 
  let sk = BigInt("0x" + keyStr) 
  let priKeySpec: cryptoFramework.ECCPriKeySpec = { 
    params: cryptoFramework.ECCKeyUtil.genECCCommonParamsSpec('NID_sm2'), 
    sk: sk, 
    algName: "SM2", 
    specType: cryptoFramework.AsyKeySpecType.PRIVATE_KEY_SPEC 
  } 
  let keypairGenerator = cryptoFramework.createAsyKeyGeneratorBySpec(priKeySpec) 
  return await keypairGenerator.generatePriKey() 
}

根据密钥参数生成sm2公钥:

import { cryptoFramework } from '@kit.CryptoArchitectureKit' 
 
export async function convertStrToPubKey(keyStr: string): Promise<cryptoFramework.PubKey> { 
  let pubKeyStr = keyStr.startsWith("04") ? keyStr.slice(2) : keyStr 
  let pkPart1 = pubKeyStr.slice(0, pubKeyStr.length / 2) 
  let pkPart2 = pubKeyStr.slice(pubKeyStr.length / 2) 
  let pk: cryptoFramework.Point = { 
    x: BigInt("0x" + pkPart1), 
    y: BigInt("0x" + pkPart2), 
  } 
  let pubKeySpec: cryptoFramework.ECCPubKeySpec = { 
    params: cryptoFramework.ECCKeyUtil.genECCCommonParamsSpec('NID_sm2'), 
    pk: pk, 
    algName: "SM2", 
    specType: cryptoFramework.AsyKeySpecType.PUBLIC_KEY_SPEC 
  } 
  let keypairGenerator = cryptoFramework.createAsyKeyGeneratorBySpec(pubKeySpec) 
  return await keypairGenerator.generatePubKey() 
}
分享
微博
QQ
微信
回复
2024-09-18 17:12:08
相关问题
基于加解密算法框架规格问题
723浏览 • 1回复 待解决
应用性能问题定位和优化指导
2541浏览 • 1回复 待解决
HarmonyOS Sm2和DES加解密问题
466浏览 • 1回复 待解决
HarmonyOS 加解密 demo
488浏览 • 1回复 待解决
HarmonyOS 加解密算法匹配
37浏览 • 1回复 待解决
关于3des加解密问题,有人知道吗?
206浏览 • 1回复 待解决
加解密算法库框架使用
889浏览 • 1回复 待解决
多种加密方式实现加解密
1055浏览 • 1回复 待解决
HarmonyOS 加解密算法如何使用
41浏览 • 1回复 待解决
HarmonyOS 请提供RAS加解密文档
390浏览 • 1回复 待解决
HarmonyOS 是否有rsa加解密例子?
22浏览 • 1回复 待解决
RSA导入外部密钥实现加解密
804浏览 • 1回复 待解决
如何进行不同规格AES加解密
843浏览 • 1回复 待解决
HarmonyOS 有RSA加解密相关吗
442浏览 • 0回复 待解决
HarmonyOS 如何进行DES加解密
581浏览 • 1回复 待解决
如何使用SM4CBC模式加解密
956浏览 • 1回复 待解决
HarmonyOS AES加解密与java无法通用
502浏览 • 1回复 待解决
求大佬告知如何进行des加解密
1946浏览 • 1回复 待解决
HarmonyOS 文档中没有查找到DES加解密
399浏览 • 1回复 待解决
HarmonyOS aes gcm加解密c/c++库
30浏览 • 1回复 待解决