加解密问题的定位指导

密钥对在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
相关问题
基于加解密算法框架规格问题
693浏览 • 1回复 待解决
应用性能问题定位和优化指导
2519浏览 • 1回复 待解决
HarmonyOS 加解密 demo
451浏览 • 1回复 待解决
HarmonyOS Sm2和DES加解密问题
422浏览 • 1回复 待解决
关于3des加解密问题,有人知道吗?
162浏览 • 1回复 待解决
多种加密方式实现加解密
1020浏览 • 1回复 待解决
加解密算法库框架使用
867浏览 • 1回复 待解决
HarmonyOS 请提供RAS加解密文档
365浏览 • 1回复 待解决
RSA导入外部密钥实现加解密
779浏览 • 1回复 待解决
如何进行不同规格AES加解密
798浏览 • 1回复 待解决
HarmonyOS 如何进行DES加解密
504浏览 • 1回复 待解决
HarmonyOS 有RSA加解密相关吗
403浏览 • 0回复 待解决
如何使用SM4CBC模式加解密
884浏览 • 1回复 待解决
HarmonyOS AES加解密与java无法通用
449浏览 • 1回复 待解决
求大佬告知如何进行des加解密
1922浏览 • 1回复 待解决
SM4采用OFB模式进行加解密
904浏览 • 1回复 待解决
HarmonyOS 文档中没有查找到DES加解密
365浏览 • 1回复 待解决