加解密问题的定位指导

密钥对在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
相关问题
HarmonyOS 加解密问题
1133浏览 • 1回复 待解决
HarmonyOS AES加解密问题
1200浏览 • 1回复 待解决
基于加解密算法框架规格问题
1710浏览 • 1回复 待解决
Web加载失败问题定位定界指导
1074浏览 • 1回复 待解决
应用性能问题定位和优化指导
3695浏览 • 1回复 待解决
HarmonyOS 关于RSA公钥加解密问题
1210浏览 • 1回复 待解决
HarmonyOS 加解密咨询
1051浏览 • 1回复 待解决
HarmonyOS 加解密 demo
1535浏览 • 1回复 待解决
HarmonyOS DEC加解密支持
1074浏览 • 1回复 待解决
HarmonyOS Sm2和DES加解密问题
1692浏览 • 1回复 待解决
HarmonyOS 加解密算法匹配
1130浏览 • 1回复 待解决
HarmonyOS 关于DES加解密疑问
1019浏览 • 1回复 待解决
HarmonyOS AES加解密咨询
1362浏览 • 1回复 待解决
HarmonyOS 是否有rsa加解密例子?
800浏览 • 1回复 待解决
关于3des加解密问题,有人知道吗?
1356浏览 • 1回复 待解决
HarmonyOS 请提供RAS加解密文档
1180浏览 • 1回复 待解决
HarmonyOS 加解密算法如何使用
1053浏览 • 1回复 待解决
多种加密方式实现加解密
2020浏览 • 1回复 待解决
HarmonyOS AES-CBC加解密
1138浏览 • 1回复 待解决
加解密算法库框架使用
1915浏览 • 1回复 待解决
HarmonyOS 如何进行DES加解密
1991浏览 • 1回复 待解决