更新记录
1.0.9(2024-04-03)
更新sm2调用
1.0.8(2024-03-28)
更新支持web版本的md5、base64、sm4
1.0.7(2024-03-26)
更新后bug修改
查看更多
平台兼容性
App |
快应用 |
微信小程序 |
支付宝小程序 |
百度小程序 |
字节小程序 |
QQ小程序 |
HBuilderX 3.6.8,Android:5.0,iOS:不支持 |
× |
× |
× |
× |
× |
× |
钉钉小程序 |
快手小程序 |
飞书小程序 |
京东小程序 |
× |
× |
× |
× |
H5-Safari |
Android Browser |
微信浏览器(Android) |
QQ浏览器(Android) |
Chrome |
IE |
Edge |
Firefox |
PC-Safari |
× |
√ |
× |
× |
× |
× |
× |
× |
× |
tq-encrypt
开发文档
UTS 语法
UTS API插件
UTS 组件插件
Hello UTS
使用说明
名称 |
描述 |
参数 |
说明 |
支持平台 |
md5Sync |
md5加密 |
str:string |
返回值:string 加密出来的字母是大写 |
Android、Web |
base64EncodeSync |
base64加密 |
str:string |
返回值:string |
Android、Web |
base64DecodeSync |
base64解密 |
str:string |
返回值:string |
Android、Web |
sm4ECBEncryptSync |
sm4 ECB加密 |
参数一:str:string 参数二:key:string |
返回值:string js中sm4加密ECB一般为默认 |
Android、Web |
sm4ECBDecryptSync |
sm4 ECB解密 |
参数一:str:string 参数二:key:string |
返回值:string |
Android、Web |
sm4CBCEncryptSync |
sm4 CBC加密 |
参数一:str:string 参数二:key:string |
返回值:string |
Android、Web |
sm4CBCDecryptSync |
sm4 CBC解密 |
参数一:str:string 参数二:key:string |
返回值:string |
Android、Web |
sm3EncryptSync |
sm3加密 |
str:string |
返回值:string |
Android |
sm2EncryptSync |
国产SM2非对称公钥加密 |
参数一:dataString : string 参数二:publicKey : string |
返回值:string |
Android |
sm2DecryptSync |
国产SM2非对称私钥解密 |
参数一:dataString : string 参数二:privateKey : string |
返回值:string |
Android |
sm2PubSignSync |
sm2私钥签名 |
参数一:dataString : string 参数二:privateKey : string |
返回值:string |
Android |
sm2PubSignValSync |
sm2验签 |
参数一:dataString : string 参数二:publicKey : string 参数三:sign : string |
返回值:boolean |
Android |
aesEncryptSync |
AES对称加密 |
参数一:str:string 参数二:key:string |
返回值:string |
Android |
aesDecryptSync |
AES对称解密 |
参数一:str:string 参数二:key:string |
返回值:string |
Android |
sha1Sync |
SHA1加密 |
str:string |
返回值:string |
Android |
sha256Sync |
SHA256加密 |
str:string |
返回值:string |
Android |
rsaEncryptSync |
RSA非对称加密 |
参数一:dataString : string 参数二:keyPair : KeyPair 参数三:type : KeyType |
返回值:string |
Android |
rsaDecryptSync |
RSA非对称解密 |
参数一:dataString : string 参数二:keyPair : KeyPair 参数三:type : KeyType |
返回值:string |
Android |
rsaSHA256PrivateSync |
RSA SHA256签名 |
参数一:dataString : string 参数二:keyPair : KeyPair |
返回值:string |
Android |
rsaMD5PrivateSync |
RSA MD5签名 |
参数一:dataString : string 参数二:keyPair : KeyPair |
返回值:string |
Android |
rsaSHA256PubValSync |
RSA SHA256签名验签 |
参数一:dataString : string 参数二:result: string 参数三:keyPair : KeyPair |
返回值:boolean |
Android |
rsaMD5PubValSync |
RSA MD5签名验签 |
参数一:dataString : string 参数二:result: string 参数三:keyPair : KeyPair |
返回值:boolean |
Android |
使用示例
<template>
<view>
<button @tap="testMD5">测试md5</button>
<button @tap="testbase64encode">测试base64encode</button>
<button @tap="testSM4">测试国产SM加密</button>
<button @tap="testaes">测试aes</button>
<button @tap="testSHA">测试sha</button>
<button @tap="testRSA">测试RSA</button>
</view>
</template>
<script lang="uts">
import { md5Sync, base64EncodeSync, rsaEncryptSync, getKeyPair, KeyType, rsaDecryptSync, rsaSHA256PrivateSync, rsaMD5PrivateSync, rsaSHA256PubValSync, rsaMD5PubValSync, base64DecodeSync, sm4ECBEncryptSync, sm4ECBDecryptSync, sm4CBCEncryptSync, sm4CBCDecryptSync, aesEncryptSync, aesDecryptSync, sha1Sync, sha256Sync, sm3EncryptSync,sm2KeyPair,sm2EncryptSync,sm2DecryptSync,sm2PubSignSync,sm2PubSignValSync } from "@/uni_modules/tq-encrypt"
export default {
data() {
return {
str: "123456"
}
},
methods: {
testMD5() {
const md5 = md5Sync(this.str)
console.log(md5);
},
testbase64encode() {
const str = base64EncodeSync("212321")
console.log(str);
const rom = base64DecodeSync(str)
console.log(rom);
},
testSM4() {
const key = 'D607A82C09F938809778B25A2F98DFA1';
let data = {
"ac": md5Sync("123456").toLowerCase(),
"grant_type": "onlyPassword",
"name": "arguments"
}
console.log(JSON.stringify(data));
// js的sm4解密一般ECB为默认
const sm4 = sm4ECBEncryptSync(JSON.stringify(data), key)
console.log(sm4);
const sm3 = sm3EncryptSync(JSON.stringify(data))
console.log(sm3);
const origin = sm4ECBDecryptSync(sm4, key)
console.log(origin);
const sm5 = sm4CBCEncryptSync(JSON.stringify(data), key)
console.log(sm5);
const sm6 = sm4CBCDecryptSync(sm5, key)
console.log(sm6);
const arr = sm2KeyPair()// 返回密钥 0 公钥 1 私钥
console.log(arr);
const sm2 = sm2EncryptSync("123456",arr[0])// 公钥加密
console.log(sm2);
const sm2origin = sm2DecryptSync(sm2,arr[1])// 私钥解密
console.log(sm2origin);
const sign = sm2PubSignSync(sm2,arr[1])// 私钥签名
console.log(sign);
const bool = sm2PubSignValSync(sm2,arr[0],sign) // 公钥验签
console.log(bool);
},
testaes() {
const res = aesEncryptSync("123456", "94E114C6A898CD39B602C8269AD33780")
console.log(res);
const dom = aesDecryptSync("3AA827B7EB35B4F522360B486EDB918C", "94E114C6A898CD39B602C8269AD33780")
console.log(dom);
},
testSHA() {
const res1 = sha1Sync("123456")
const res2 = sha256Sync("123456")
console.log(res1, res2);
},
testRSA() {
const key = getKeyPair()
const res = rsaEncryptSync("123456", key, KeyType.PUB)//公钥加密
console.log(res);
const origin = rsaDecryptSync(res, key, KeyType.PRI)//私钥解密
console.log(origin);
const res1 = rsaEncryptSync("123456", key, KeyType.PRI)//私钥加密
console.log(res1);
const origin1 = rsaDecryptSync(res1, key, KeyType.PUB)//公钥解密
console.log(origin1);
const res2 = rsaSHA256PrivateSync("123456", key)//私钥对明文数据SHA256签名
console.log(res2);
const res3 = rsaMD5PrivateSync("123456", key)//私钥对明文数据MD5签名
console.log(res3);
const res4 = rsaSHA256PubValSync("123456", res2, key) // 公钥对SHA256签名验签
console.log(res4);
const res5 = rsaMD5PubValSync("123456", res3, key) // 公钥对MD5签名验签
console.log(res5);
}
}
}
</script>
注意
1、本插件包含原生第三方库需要配置gradle库和sdk库
Android UTS扩展开发
HBuilder X新版本更新后需要升级gradle库,本人使用的版本是gradle8.2.1配置jdk路径为jdk17,其他版本可使用官方推荐版本
ps: 如果有问题可以咨询作者,本人QQ:1307905648,也可以在评论区留言截图配置环境和错误信息