加解密问题的定位指导-鸿蒙开发者社区-51CTO.COM

加解密问题的定位指导

密钥对在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 加解密问题
493浏览 • 1回复 待解决
HarmonyOS AES加解密问题
565浏览 • 1回复 待解决
Web加载失败问题定位定界指导
399浏览 • 1回复 待解决
基于加解密算法框架规格问题
1036浏览 • 1回复 待解决
应用性能问题定位和优化指导
2837浏览 • 1回复 待解决
HarmonyOS 关于RSA公钥加解密问题
645浏览 • 1回复 待解决
HarmonyOS 加解密 demo
936浏览 • 1回复 待解决
HarmonyOS 加解密咨询
489浏览 • 1回复 待解决
HarmonyOS DEC加解密支持
401浏览 • 1回复 待解决
HarmonyOS Sm2和DES加解密问题
950浏览 • 1回复 待解决
HarmonyOS AES加解密咨询
569浏览 • 1回复 待解决
HarmonyOS 加解密算法匹配
400浏览 • 1回复 待解决
HarmonyOS 关于DES加解密疑问
503浏览 • 1回复 待解决
关于3des加解密问题,有人知道吗?
654浏览 • 1回复 待解决
HarmonyOS AES-CBC加解密
464浏览 • 1回复 待解决
多种加密方式实现加解密
1380浏览 • 1回复 待解决
加解密算法库框架使用
1192浏览 • 1回复 待解决
HarmonyOS 加解密算法如何使用
369浏览 • 1回复 待解决
HarmonyOS 请提供RAS加解密文档
731浏览 • 1回复 待解决
HarmonyOS 是否有rsa加解密例子?
270浏览 • 1回复 待解决
如何进行不同规格AES加解密
1289浏览 • 1回复 待解决