Android SM4加密与java中的url进行编码和解码

项目需求要用SM4加密,搜了搜用的多,但有用的少,记录一下。

添加依赖:

implementation 'cn.hutool:hutool-all:5.4.5'

然后再下载这个jar包到本地,引入
https://download.csdn.net/download/wuqingsen1/86823072

implementation files('libs/bcprov-jdk15on-1.65.01.jar')

或者,添加依赖,但我一直失败:

    implementation 'org.bouncycastle:bcprov-jdk15on:1.58'

工具类:

package com.sinosoft.cs.utils.common;

import cn.hutool.crypto.symmetric.SymmetricCrypto;

/**
 * wuqingsen on 10/25/22
 * Mailbox:807926618@qq.com
 * annotation:
 */
public class sm4Demo {

    //key必须是16字节,即128位
    final static String key = "JeF8U9wHFOMfs2Y8";

    //指明加密算法和秘钥
    static SymmetricCrypto sm4 = new SymmetricCrypto("SM4/ECB/PKCS5Padding", key.getBytes());

    //加密为16进制,也可以加密成base64/字节数组
    public static String encrypt16Sm4(String plaintext) {
        return sm4.encryptBase64(plaintext);
    }
    
    //加密为base64/字节数组
    public static String encrypt64Sm4(String plaintext) {
        return sm4.encryptBase64(plaintext);
    }

    //解密
    public static String decrypt16Sm4(String ciphertext) {
        return sm4.decryptStr(ciphertext);
    }
}

可以加密为16进制或base64,按个人需求。

使用:

sm4Demo.encrypt64Sm4("{\"salesNo\":\"123\",\"time\":123}");




java中的url进行编码和解码:

 URLEncoder.encode(a, "UTF-8");

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android SM2、SM3、SM4 算法支持 Service Provider 及证书制作软件包 国密算法 JCAJCE Service Provider,适应版本 Android 4.2.2~7.0 支持 SM2 的 KeyFactory、KeyPairGenerator、Cipher、Signature、X.509 CertificateFactory 接口 支持 SM3 的 MessageDigest 接口、SM3withSM2 混合算法 支持 SM4 的 Cipher、KeyFactory、KeyGenerator、SecretKey 接口、相关算法 CMAC-SM4、Poly1305-SM4 增加 java.security.PublicKey 的子类 SM2PublicKey 增加 java.security.PrivateKey 的子类 SM2PrivateKey 全功能支持 SM3withSM2 算法的 X.509 证书结构体解释与密码运算 支持 BKS、PKCS#12 KeyStore 生成、解释、验算 X.509v1/v3 证书,签名算法支持 SM3withSM2、主流 RSA、DSA、ECDSA.... 生成、解释、验算 PKCS#10 证书申请,签名算法支持 SM3withSM2、主流 RSA、DSA、ECDSA.... *** 无须打包 BouncyCastle 支持库,体积小、节约内存 *** 请参阅 testSM.java、testCERT.java 文件列表: 1、AndroidSM.jar -- SM2、SM3、SM4 算法/证书支持的 JCA/JCE Service Provider 类库 2、AndroidCRT.jar -- X.509 数字证书/PKCS#10 证书申请相关类库 3、bc422.jar -- BouncyCastle 加密库,Android 4.2.2 内置版本(由真机导出dex文件转换而得,仅用于编译时选用,勿打包到apk文件) 4、testSM.java -- SM2、SM3、SM4 算法相关类引用范例 5、testCERT.java -- X.509 数字证书/PKCS#10 证书申请相关类引用范例 6、readme.txt -- 本文 因条件及精力限制,各类、方法的实现未经严格彻底的测试,不宜用于商业用途软件的开发。 如欲将本开发包发布、上传、拷贝、共享等,务必保持其内容完整性(包括本文) 如有需要帮助或者索取源码,请联系 suntongo@qq.com, suntongo@hotmail.com
Java使用SM4加密算法,你需要导入两个包:bcprov-jdk15on-1.59.jar和hutool-all-4.6.17.jar。你可以从百度网盘获取这两个包,提取码是wwmy。然后,将这两个包添加到你的Maven项目SM4加密算法与解密算法类似,唯一的区别是使用的轮子密钥的顺序不同。在编码过程,通过一个标志性数据CryptFlag来确定是产生加密轮子密钥还是解密轮子密钥。当CryptFlag为1时进行加密操作,CryptFlag为0时进行解密操作。 SM4分组密码算法是一个迭代分组密码算法,由加密算法和密钥扩展算法组成。它采用非平衡Feistel结构,明文分组长度为128bit,密钥长度为128bit。加密算法和密钥扩展算法都采用32轮非线性迭代结构。解密算法与加密算法的结构相同,只是轮密钥的使用顺序相反,解密轮密钥是加密轮密钥的逆序。 所以,在Java使用SM4加密算法,你需要导入相关的包,并根据CryptFlag的值来确定是进行加密操作还是解密操作。 #### 引用[.reference_title] - *1* [基于JAVASM4文件加密解密,可以直接使用](https://blog.csdn.net/weixin_44462064/article/details/112170722)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [SM4加密算法(JAVA语言实现)](https://blog.csdn.net/Fly_hps/article/details/83096057)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值