SpringBoot sha 加密

本文介绍如何使用Java生成字符串的SHA1哈希值。通过将字符串转换为UTF-8编码的字节数组,然后应用SHA1算法来创建一个安全的哈希。此方法常用于数据完整性校验及密码存储。
String value="123456";
DigestUtils.sha1Hex(value.getBytes(Charset.forName("UTF-8")))

在Spring Boot中可以使用多种加密方式,包括对称加密、非对称加密和哈希加密等。 1. 对称加密 对称加密是指加密和解密使用同一个密钥的加密方式,常见的对称加密算法有DES、3DES、AES等。Spring Boot中可以使用Spring Security模块提供的对称加密功能,例如: ```java String password = "123456"; String secretKey = "mySecretKey"; String encrypted = EncryptUtil.encrypt(password, secretKey); String decrypted = EncryptUtil.decrypt(encrypted, secretKey); System.out.println("加密后:" + encrypted); System.out.println("解密后:" + decrypted); ``` 其中EncryptUtil是一个自定义的工具类,实现了对称加密的加解密功能。 2. 非对称加密 非对称加密是指加密和解密使用不同的密钥的加密方式,常见的非对称加密算法有RSA、DSA等。Spring Boot中可以使用Java Cryptography Extension (JCE)提供的非对称加密功能,例如: ```java String password = "123456"; KeyPair keyPair = RSAUtil.generateKeyPair(); String publicKey = RSAUtil.getPublicKey(keyPair); String privateKey = RSAUtil.getPrivateKey(keyPair); String encrypted = RSAUtil.encrypt(password, publicKey); String decrypted = RSAUtil.decrypt(encrypted, privateKey); System.out.println("公钥:" + publicKey); System.out.println("私钥:" + privateKey); System.out.println("加密后:" + encrypted); System.out.println("解密后:" + decrypted); ``` 其中RSAUtil是一个自定义的工具类,实现了非对称加密的生成密钥对、获取公钥和私钥,以及加解密功能。 3. 哈希加密 哈希加密是指将原始数据通过哈希算法转换成一段固定长度的无法还原的数据的加密方式,常见的哈希算法有MD5、SHA-1、SHA-256等。Spring Boot中可以使用Java提供的MessageDigest类实现哈希加密功能,例如: ```java String password = "123456"; String salt = "mySalt"; String encrypted = HashUtil.hash(password, salt); System.out.println("加密后:" + encrypted); ``` 其中HashUtil是一个自定义的工具类,实现了哈希加密的功能,其中加入了盐值来增加加密的安全性。 需要注意的是,加密并不能完全保证数据的安全性,只能增加数据被破解的难度。对于敏感数据,建议使用HTTPS等更高级别的安全协议来保护数据的传输和存储。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

圈圈的博客

您的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值