md5加密文件_小白学Java(实现MD5加密技术)

     MD5的典型应用是对一段信息(Message)产生信息摘要(Message-Digest),以防止被篡改。比如,在UNIX下有很多软件在下载的时候都有一个文件名相同,文件扩展名为.md5的文件,在这个文件中通常只有一行文本,大致结构如:  MD5 (tanajiya.tar.gz) = 0ca175b9c0f726a831d895e269332461

     我们常常在某些软件下载站点的某软件信息中看到其MD5值,它的作用就在于我们可以在下载该软件后,对下载回来的文件用专门的软件(如Windows MD5 Check等)做一次MD5校验,以确保我们获得的文件与该站点提供的文件为同一文件。利用MD5算法来进行文件校验的方案被大量应用到软件下载站、论坛数据库、系统文件安全等方面。

6a023f3812342bf1c8c6f84f69a158d8.png

MD5加密其实很简单引用了maven的依赖后一个方法就可以实现了

废话不多说,上依赖

         <dependency>            <groupId>commons-codecgroupId>            <artifactId>commons-codecartifactId>            <version>1.6version>        dependency>

添加依赖后,直接在密码上调用方法就可以了DigestUtils.md5Hex(MD5.PASSWORD);

import org.apache.commons.codec.digest.DigestUtils;public class MD5 {    public static final String PASSWORD ="TomTong";    public static final String SOLT="nb666";    public  static  final  String SQl = "md5";    public static void main(String[] args) {        String admin = DigestUtils.md5Hex(MD5.PASSWORD);        String s = DigestUtils.md5Hex(admin+MD5.SOLT);        System.out.println("______第一次加密__________");        System.out.println(admin);        System.out.println("__________第二次加密____________");        System.out.println(s);        System.out.println("_____________第三次加密_________");        String s1 = DigestUtils.md5Hex(s + MD5.SQl);        System.out.println(s1);           }

我这里为了更加安全加密了三层,打印出来是这样子的,可以直接保存到数据库中了

793a2ed4de79e57b43bba7c27149b61d.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答关于Java实现MD5加密解密的问题。 Java提供了MessageDigest类来实现MD5加密,可以通过以下代码实现: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return Base64.getEncoder().encodeToString(bytes); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 上述代码中,`encrypt`方法用于实现MD5加密,参数为需要加密的字符串,返回加密后的字符串。`decrypt`方法用于实现MD5加密后的字符串的解密,但是由于MD5是不可逆的加密算法,所以我们无法进行解密,因此在该方法中直接抛出了`UnsupportedOperationException`异常。 使用示例: ```java public class Main { public static void main(String[] args) { String password = "123456"; String encryptedPassword = MD5Util.encrypt(password); System.out.println("加密后的密码:" + encryptedPassword); } } ``` 输出结果: ``` 加密后的密码:MTIzNDU2Nzg5MDM0NTY3OA== ``` 可以看到,加密后的密码是一串Base64编码的字符串。如果需要将其转换为16进制字符串,可以使用以下代码: ```java import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return new BigInteger(1, bytes).toString(16); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 这样输出的加密后的密码就是16进制的字符串了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值