UNPKG

@ivujs/i-utils

Version:

前端模块化 JavaScript 工具库

123 lines (109 loc) 3.49 kB
'use strict'; var sm2 = require('./sm2.cjs'); // 获取密钥对 /** * sm2 生成公钥和私钥 * @param {String} str 字符串 * @param {Number} rnd 随机数 * @returns {Object} 返回公钥和私钥 */ function generateKeyPairHex(str, rnd) { return sm2.generateKeyPairHex(str, rnd); } /** * sm2 压缩公钥 * @param {String} publicKey 公钥 * @returns {String} 返回公钥字符串 */ function compressPublicKeyHex(publicKey) { return sm2.compressPublicKeyHex(publicKey); } /** * sm2 对比公钥是否等价 * @param {String} publicKey 公钥 * @param {String} compressedPublicKey 压缩后的公钥 * @returns {Boolean} 返回结果 */ function comparePublicKeyHex(publicKey, compressedPublicKey) { return sm2.comparePublicKeyHex(publicKey, compressedPublicKey); } // 验证密钥对 /** * sm2 验证公钥 * @param {String} publicKey 公钥,也可以传压缩后的公钥 * @returns {Boolean} 返回结果 */ function verifyPublicKey(publicKey) { return sm2.verifyPublicKey(publicKey); } // 加密解密 /** * sm2 加密 * @param {String} str 字符串 * @param {String} publicKey 公钥 * @param {Number} cipherMode 加密模式,1(C1C3C2)和0(C1C2C3),默认1 * @returns {String} 返回加密后的字符串 */ function encrypt(str, publicKey, cipherMode = 1) { return sm2.doEncrypt(str, publicKey, cipherMode); } /** * sm2 解密 * @param {String} str 字符串 * @param {String} privateKey 私钥 * @param {Number} cipherMode 解密模式,1(C1C3C2)和0(C1C2C3),默认1 * @param {Object} outputConfig 输出结果配置,{output:'string/array'} * @returns {String,Array} 返回解密后的数据 */ function decrypt(str, privateKey, cipherMode = 1, outputConfig = { output: "string" }) { return sm2.doDecrypt(str, privateKey, cipherMode, outputConfig); } // 签名验签 /** * sm2 生成签名 * @param {String} str 字符串 * @param {String} privateKey 私钥 * @param {Object} signatureConfig 签名配置 * @returns {String} 返回签名信息 */ function doSignature(str, privateKey, signatureConfig) { return sm2.doSignature(str, privateKey, signatureConfig); } /** * sm2 验证签名 * @param {String} str 字符串 * @param {String} signHex 生成签名的信息 * @param {String} publicKey 公钥 * @param {Object} verifyConfig 验证配置 * @returns {String} 返回结果 */ function doVerifySignature(str, signHex, publicKey, verifyConfig) { return sm2.doVerifySignature(str, signHex, publicKey, verifyConfig); } // 获取椭圆曲线点 /** * sm2 获取椭圆曲线点 * @returns {Object} 返回椭圆曲线点,可在sm2签名时传入 */ function getPoint() { return sm2.getPoint(); } // 根据私钥获取公钥 /** * sm2 根据私钥获取公钥 * @param {String} privateKey 私钥 * @returns {String} 返回公钥 */ function getPublicKeyFromPrivateKey(privateKey) { return sm2.getPublicKeyFromPrivateKey(privateKey); } exports.comparePublicKeyHex = comparePublicKeyHex; exports.compressPublicKeyHex = compressPublicKeyHex; exports.decrypt = decrypt; exports.doSignature = doSignature; exports.doVerifySignature = doVerifySignature; exports.encrypt = encrypt; exports.generateKeyPairHex = generateKeyPairHex; exports.getPoint = getPoint; exports.getPublicKeyFromPrivateKey = getPublicKeyFromPrivateKey; exports.verifyPublicKey = verifyPublicKey;