更新记录

1.0.9(2024-04-03)

更新sm2调用

1.0.8(2024-03-28)

更新支持web版本的md5、base64、sm4

1.0.7(2024-03-26)

更新后bug修改

查看更多

平台兼容性

Vue2 Vue3
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,也可以在评论区留言截图配置环境和错误信息

隐私、权限声明

1. 本插件需要申请的系统权限列表:

2. 本插件采集的数据、发送的服务器地址、以及数据用途说明:

3. 本插件是否包含广告,如包含需详细说明广告表达方式、展示频率:

许可协议

MIT协议

使用中有什么不明白的地方,就向插件作者提问吧~ 我要提问