iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >Java使用MD5加盐对密码进行加密处理,附注册和登录加密解密处理
  • 145
分享到

Java使用MD5加盐对密码进行加密处理,附注册和登录加密解密处理

java开发语言 2023-08-17 07:08:07 145人浏览 薄情痞子
摘要

前言 在开发的时候,有一些敏感信息是不能直接通过明白直接保存到数据库的。最经典的就是密码了。如果直接把密码以明文的形式入库,不仅会泄露用户的隐私,对系统也是极其的不厉,这样做是非常危险的。 那么我们就需要对这些铭文进行加密。 Java常用加

前言

开发的时候,有一些敏感信息是不能直接通过明白直接保存到数据库的。最经典的就是密码了。如果直接把密码以明文的形式入库,不仅会泄露用户的隐私,对系统也是极其的不厉,这样做是非常危险的。

那么我们就需要对这些铭文进行加密。

Java常用加密手段

现在市场是加密的方式已经有很多了,像Base64加密算法(编码方式),MD5加密(消息摘要算法,验证信息完整性),对称加密算法,非对称加密算法,数字签名算法,数字证书,CA认证等等。。

场景加密手段应用场景

Base64应用场景:图片转码(应用于邮件,img标签,Http加密)

MD5应用场景:密码加密、imei加密、文件校验

非对称加密:电商订单付款、银行相关业务

MD5加密的风险

如果直接使用MD5进行加密,其实是不安全的,这是是可以验证的,比如下面这个例子:

我直接使用MD5对123456的密码进行加密。看着很牛是吧,一串随机数,但是其实一碰就碎

在这里插入图片描述

接下来就使用大家常用的一个网站进行破解:MD5破解网站

把刚才生成的MD5加密后的密码进行解密。

轻松破解,别说黑客了,这个网站都能破解出来,那风险有多大就不用说了

在这里插入图片描述

所以我们需要采取一些措施,用于二次不强MD5加密后的密码,针对这种方式,现在大多数采取的方式就是加盐

什么是盐?

盐(salt)一般是一个随机生成的字符串或者常量。我们将盐与原始密码连接在一起(放在前面或后面都可以),然后将拼接后的字符串加密。salt这个值是由系统随机生成的,并且只有系统知道。即便两个用户使用了同一个密码,由于系统为它们生成的salt值不同,散列值也是不同的。

加salt可以一定程度上解决这一问题。所谓加salt方法,就是加点“佐料”。其基本想法是这样的:当用户首次提供密码时(通常是注册时),由系统自动往这个密码里撒一些“佐料”,然后再散列。而当用户登录时,系统为用户提供的代码撒上同样的“佐料”,然后散列,再比较散列值,已确定密码是否正确。

这样也就变成了将密码+自定义的盐值来取MD5。但是如果黑客拿到了你的固定的盐值,那这样也不安全了。所以比较好的做法是用随机盐值。用户登陆时再根据用户名取到这个随机的盐值来计算MD5。

个人建议把盐设置成随机数而不是常量,这样更加安全。

引入MD5工具

坐标如下:

   commons-codec   commons-codec

在这里插入图片描述

编写MD5加盐工具类

这种对铭文加密的操作,我们可以封装成一个工具类,在这里我们主要进行对明文密码进行MD5加密,并且进行二次加盐加密,以及对比加盐后的密码和初始密码是否相同。

直接把全部代码附上:

package com.wyh.util;import org.apache.commons.codec.binary.Hex;import java.security.MessageDigest;import java.security.NoSuchAlGorithmException;import java.util.Random;public class SaltMD5Util {        public static String MD5(String input) {        MessageDigest md5 = null;        try {            // 生成普通的MD5密码            md5 = MessageDigest.getInstance("MD5");        } catch (NoSuchAlgorithmException e) {            return "check jdk";        } catch (Exception e) {            e.printStackTrace();            return "";        }        char[] charArray = input.toCharArray();        byte[] byteArray = new byte[charArray.length];        for (int i = 0; i < charArray.length; i++)            byteArray[i] = (byte) charArray[i];        byte[] md5Bytes = md5.digest(byteArray);        StringBuffer hexValue = new StringBuffer();        for (int i = 0; i < md5Bytes.length; i++) {            int val = ((int) md5Bytes[i]) & 0xff;            if (val < 16)                hexValue.append("0");            hexValue.append(Integer.toHexString(val));        }        return hexValue.toString();    }        public static String generateSaltPassword(String passWord) {        Random random = new Random();        //生成一个16位的随机数,也就是所谓的盐                StringBuilder stringBuilder = new StringBuilder(16);        stringBuilder.append(random.nextInt(99999999)).append(random.nextInt(99999999));        int len = stringBuilder.length();        if (len < 16) {            for (int i = 0; i < 16 - len; i++) {                stringBuilder.append("0");            }        }        // 生成盐        String salt = stringBuilder.toString();        //将盐加到明文中,并生成新的MD5码        password = md5Hex(password + salt);        //将盐混到新生成的MD5码中,之所以这样做是为了后期更方便的校验明文和秘文,也可以不用这么做,不过要将盐单独存下来,不推荐这种方式        char[] cs = new char[48];        for (int i = 0; i < 48; i += 3) {            cs[i] = password.charAt(i / 3 * 2);            char c = salt.charAt(i / 3);            cs[i + 1] = c;            cs[i + 2] = password.charAt(i / 3 * 2 + 1);        }        return new String(cs);    }        public static boolean verifySaltPassword(String password, String md5) {        //先从MD5码中取出之前加的盐和加盐后生成的MD5码        char[] cs1 = new char[32];        char[] cs2 = new char[16];        for (int i = 0; i < 48; i += 3) {            cs1[i / 3 * 2] = md5.charAt(i);            cs1[i / 3 * 2 + 1] = md5.charAt(i + 2);            cs2[i / 3] = md5.charAt(i + 1);        }        String salt = new String(cs2);        //比较二者是否相同        return md5Hex(password + salt).equals(new String(cs1));    }        private static String md5Hex(String src) {        try {            MessageDigest md5 = MessageDigest.getInstance("MD5");            byte[] bs = md5.digest(src.getBytes());            return new String(new Hex().encode(bs));        } catch (Exception e) {            return null;        }    }    public static void main(String args[]) {        // 原密码        String password = "123456";        System.out.println("明文(原生)密码:" + password);        // MD5加密后的密码        String MD5Password = MD5(password);        System.out.println("普通MD5加密密码:" + MD5Password);        // 获取加盐后的MD5值        String SaltPassword = generateSaltPassword(password);        System.out.println("加盐后的MD密码:" + SaltPassword);        System.out.println("加盐后的密码和原生密码是否是同一字符串:" + verifySaltPassword(password, SaltPassword));    }}

测试盐加密强度

这样我们就可以简单的测试下,这传说中的盐是否真的这么厉害,还是刚才的套路,我们定义一个明文为123456的密码。然后再对生成的MD5密码进行加盐处理,分别进行破解,以及对比加盐后的密码和初始密码是否相同。

在这里插入图片描述

拿着MD5的密码进行破解,不用想,基本就是一碰就碎

在这里插入图片描述

然后试试加了盐之后的把,你会发现它破解不了。

在这里插入图片描述

有了这些的基础后,我们就可以对用户注册和登录分别进行加盐加密,以及破解密码对比是否一致了

注册加密

其实很简单,再原有的密码上进行加密即可:

在这里插入图片描述

@PostMapping(value = "/save")    public Result save(@RequestBody User user) {        return userService.saveUser(user);    }  @Override    public Result saveUser(User user) {        // 密码 进行MD5加盐再入库        user.setPassword(SaltMD5Util.generateSaltPassword(user.getPassword()));        // 默认头像        user.setImage("http://localhost:9090/upload/defaultUserImage.jpg");        if (this.save(user)) {            return Result.ok(user);        }        return Result.fail("保存用户信息失败");    }

接口简单测试下把,可以看到是以加密的方式入库的:

在这里插入图片描述

登录解密

加密后入库了可不够,还要进行对比呢,随意登录也要处理下:

@GetMapping(value = "/login")    public Result login(User user) {        return userService.login(user);    }     public Result login(User user) {        // 账号        String account = user.getAccount();        // 密码        String password = user.getPassword();        // 如果账号或者密码为空,返回错误信息        if (StringUtils.isEmpty(account) || StringUtils.isEmpty(password)) {            return Result.fail("账号和密码都不能为空!");        }        // 根据账号和密码查询对应的用户信息        User loginUser = this.query()                .eq("account", account)                .one();        if (!StringUtils.isEmpty(loginUser)) {            // 获取该用户在数据库里面的加密过的密码            String saltPassword = loginUser.getPassword();            // 输入的密码和加密后的密码进行比较            boolean passwordFlag = SaltMD5Util.verifySaltPassword(password, saltPassword);            // 如果根据账号查询和校验加密密码失败,则返回错误信息            if (StringUtils.isEmpty(loginUser) || !passwordFlag) {                return Result.fail("登录失败,账号或者密码错误!");            }            // 如果账号状态被禁用了            if (loginUser.getStatus().equals(ACCOUNT_DISABLE.getCode())) {                return Result.fail("登录失败,该账号已被引用,请联系管理员!", loginUser);            }            // 存在的话返回查询到的用户信息            return Result.ok(loginUser);        }        return Result.fail("登录失败,账号或者密码错误!");    }

我们还以刚才注册的用户为例进行登录,可以看到虽然库里是加密后的密码,我们输入的是明文,但是一样可以匹配上的:

在这里插入图片描述

总结

加密真的很重要,重要的信息千万不能以明文保存!!!

来源地址:https://blog.csdn.net/weixin_46713508/article/details/129152215

--结束END--

本文标题: Java使用MD5加盐对密码进行加密处理,附注册和登录加密解密处理

本文链接: https://www.lsjlt.com/news/372521.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java使用MD5加盐对密码进行加密处理,附注册和登录加密解密处理
    前言 在开发的时候,有一些敏感信息是不能直接通过明白直接保存到数据库的。最经典的就是密码了。如果直接把密码以明文的形式入库,不仅会泄露用户的隐私,对系统也是极其的不厉,这样做是非常危险的。 那么我们就需要对这些铭文进行加密。 Java常用加...
    99+
    2023-08-17
    java 开发语言
  • Java利用MD5加盐实现对密码进行加密处理
    目录前言Java常用加密手段场景加密手段应用场景MD5加密的风险什么是盐引入MD5工具类编写MD5加盐工具类测试盐加密强度注册加密登录解密总结前言 在开发的时候,有一些敏感信息是不能...
    99+
    2023-02-22
    Java MD5 密码加密 Java 密码加密 Java MD5 Java 加密
  • 如何在JAVA中使用MD5加密对密码进行加密
    本篇文章为大家展示了如何在JAVA中使用MD5加密对密码进行加密,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。新建Md5.javapackage com.loger.md5;import java....
    99+
    2023-05-31
    java md5加密 ava
  • Java怎么利用MD5实现对密码进行加密处理
    本文小编为大家详细介绍“Java怎么利用MD5实现对密码进行加密处理”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java怎么利用MD5实现对密码进行加密处理”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Jav...
    99+
    2023-07-05
  • 如何在Java中使用RSA加密对密码进行加密解密
    这期内容当中小编将会给大家带来有关如何在Java中使用RSA加密对密码进行加密解密,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。具体如下:public static void ...
    99+
    2023-05-31
    java rsa加密 ava
  • java如何使用Apache commons codec进行MD5加密,BASE64加密解密,执行系统命令
    这篇文章将为大家详细讲解有关java如何使用Apache commons codec进行MD5加密,BASE64加密解密,执行系统命令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。编写代码之前先来介绍一下...
    99+
    2023-05-30
    java apache
  • 如何使用vbs对QWERTY密码进行加密与解密
    这篇文章主要介绍如何使用vbs对QWERTY密码进行加密与解密,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在做Arthur's Online Riddle的时候有这么一道题目: If QWERTY = AB...
    99+
    2023-06-08
  • Java和PHP完美对接AES加解密,密钥处理要注意
    对于应用程序进行加密保护,AES算法被广泛使用。但是在使用Java和PHP进行AES加解密时,很多人都会遇到一些困难。本文就来介绍一下如何实现Java和PHP的完美对接AES加解密。 在进行AES加解密时,我们需要注意以下几个方面: 确定加...
    99+
    2023-08-31
    php java
  • C# 使用SHA1算法对密码进行加密
    C#中如何使用SHA1对密码进行加密呢?先声明一下,对于编程小编在这个方面还是个小白,如果小编有说的不对的地方,请各位大佬联系小编,小编好进行修改。好了不说废话了上图。在这里呢小编创...
    99+
    2024-04-02
  • SpringBoot实现Mysql使用MD5进行密码加密的示例
    项目开发中为了保护用户隐私安全,一般都会用MD5进行密码加密 以下就简单举例SpringBoot 实现Mysql使用MD5进行密码加密做一个简单的例子 看下数据库,这边简单做了用户表...
    99+
    2024-04-02
  • 如何在java中使用RSA算法对密码进行加密与解密
    本篇文章给大家分享的是有关如何在java中使用RSA算法对密码进行加密与解密,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。前言:  RSA是第一个比较完善的公开密钥算...
    99+
    2023-05-31
    java rsa算法 ava
  • 如何使用PHP进行加密和解密?
    PHP是一种流行的服务器端脚本语言,它可以用来创建复杂的Web应用程序。其中一个重要的功能是加密和解密敏感数据。在本文中,我们将讨论如何使用PHP进行加密和解密。对称加密算法对称加密算法是最常见的加密方式之一,也被称为单密钥加密。它使用同一...
    99+
    2023-05-22
    PHP加密(Encryption) PHP解密(Decryption) 对称加密(Symmetric encryptio
  • 如何使用openssl对文件进行加密和解密
    这篇文章主要介绍如何使用openssl对文件进行加密和解密,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!openssl是一个安全套接字层密码库,囊括主要的密码算法、常用密钥、证书封装管理功能及实现ssl协议。Open...
    99+
    2023-06-27
  • PHP使用Aeses进行加密处理的方法
    这篇“PHP使用Aeses进行加密处理的方法”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“PHP使用Aeses进行加密处理的方法”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章...
    99+
    2023-06-06
  • Vue怎么使用MD5对前后端进行加密
    这篇文章主要介绍了Vue怎么使用MD5对前后端进行加密的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue怎么使用MD5对前后端进行加密文章都会有所收获,下面我们一起来看看吧。前端在public下面新建一个MD...
    99+
    2023-06-29
  • C#如何使用SHA1算法对密码进行加密
    这篇文章给大家分享的是有关C#如何使用SHA1算法对密码进行加密的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。C#中如何使用SHA1对密码进行加密呢?在这里呢小编创建的是ASP.NET Web 项目应用程序,wi...
    99+
    2023-06-14
  • 使用springboot怎么对数据库密码进行加密
    使用springboot怎么对数据库密码进行加密?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.导入依赖<dependency> &nb...
    99+
    2023-06-14
  • 如何使用PHP进行数据加密和解密?
    随着网络技术的快速发展,数据安全已经成为了网络应用开发中最重要的问题之一。数据加密是一种保护敏感信息的方式,可以通过加密算法将数据转化为一串看似无意义的字符,使得未经授权的人无法读取这些信息。PHP是一种广泛使用的服务器端脚本语言,它提供了...
    99+
    2023-05-21
    PHP 数据加密 数据解密
  • Vue使用MD5对前后端进行加密的实现
    目录前端后端前后端分离的项目,遇到了对密码进行加密的情况,在前端或者是在后端加密都是可以的。但是从用户数据的安全性来讲,前后端是都需要进行加密的。后端不加密的话,数据库中存储明文密码...
    99+
    2024-04-02
  • 怎么在java中使用Base64进行加密与解密
    怎么在java中使用Base64进行加密与解密?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Base64加密与解密操作package cn.mldn.demo;i...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作