当前位置: 首页 > news >正文

dedecms 网站首页标签千锋培训机构官网

dedecms 网站首页标签,千锋培训机构官网,.net做网站用什么框架,seo的特点是什么文章目录1. 前言2. 密码加密1. 前言 本文 主要实现 对密码进行加密 ,因为 使用 md5 容易被穷举 (彩虹表) 而破解 ,使用 spring security 框架又太大了 (杀鸡用牛刀) 。   所以本文 就自己实现一个密码加密 . 2. 密码加密 这里我们通过 加盐是方式 来 对…

文章目录

  • 1. 前言
  • 2. 密码加密

1. 前言

本文 主要实现 对密码进行加密 ,因为 使用 md5 容易被穷举 (彩虹表) 而破解 ,使用 spring security 框架又太大了 (杀鸡用牛刀) 。

所以本文 就自己实现一个密码加密 .

2. 密码加密

这里我们通过 加盐是方式 来 对密码进行加密 .

加盐 通常分为两部分 :

  1. 盐值 : 通常使用随机数
  2. 加密数据


将盐值与加密数据合在一起 就是 加盐数据了 , 加盐数据通常来说是安全的


这里我们 盐值 是 随机的 每次加盐的数字都是不同的,这里通过穷举 来 破解我们的数据 假设破解 一条数据 花费的时间 1 天 , 我们 有 1 千w 个数据, 一个数据

是一天 , 那么 1 千 w 个数 , 全部破解 时间是非常多的 .


这里成本大于利益 , 那么谁去破解呢 , 所以这样做 我们的密码 就是安全的 .


知道加盐 , 下面就来自己实现一个加盐的方法

  1. 加密 : 随机盐 + $ + 最终加密密码
  2. 解密 : 先通过 $ 进行分割 , 得到随机盐 + 最终密码 ,然后通过 md5 对 新输入的密码 与 得到的随机盐 进行加密 , 将得到的 新的加密密码 和 之前分割得到的 最终密码 进行对比 如果 相等 那么 就是相同的密码 返回 true,如果不相等 就是不同的密码 返回 false


代码实现 :

这里我采用 的 是 使用 hutool 中的 MD5 进行 加密 的 所以需要引入 依赖

  <!--        添加 hutool --><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.12</version></dependency>


创建一个 PasswordUtil , 在这个类里面完成我们的加密和 解密 .

package com.example.usermanager.tools;import cn.hutool.core.util.IdUtil;
import cn.hutool.crypto.SecureUtil;
import org.springframework.util.StringUtils;import java.util.UUID;/*** 密码工具类* 1. 加密 (加盐)* 2. 解密*/public class PasswordUtil {/*** 加密 (加盐)** @param password* @return*///         生成的 UUID 带有 - : UUID.randomUUID();public static String encrypt(String password) {// 生成 uuid 不加 - 的 .// 随机盐值String salt = IdUtil.simpleUUID();// 密码 (随机盐值 + 密码)String finalPassword = SecureUtil.md5(salt + password);return salt + "$" + finalPassword;}/*** 解密** @param password 要验证的密码 (未加密)* @return 数据库中的加了盐值的密码*/public static boolean decrypt(String password, String securePassword) {boolean result = false;if (StringUtils.hasLength(password) && StringUtils.hasLength(securePassword)) {if (securePassword.length() == 65 && securePassword.contains("$")) {// 注意 : $ 是特殊字符 使用 split 需要转义String[] securePasswordArr = securePassword.split("\\$");// 盐值String salt = securePasswordArr[0];// 根据盐值加密的密码String finalPassword = securePasswordArr[1];// 使用同样的加密算法 和 随机盐值生成最终的加密的密码password = SecureUtil.md5(salt + password);// 进行对比if (finalPassword.equals(password)) {result = true;}}}return result;}public static void main(String[] args) {String password = "123456";String dbPassword = PasswordUtil.encrypt(password);System.out.println("加密密码 " + dbPassword);boolean result = PasswordUtil.decrypt("123456",dbPassword);String password2 = "123456789";boolean result2 = PasswordUtil.decrypt(password2,dbPassword);System.out.println(result);System.out.println(result2);}
}


效果 :

在这里插入图片描述

扩展 : 这里我们可以 对 加密密码 进行一个对称加密 ,对称加密后得到一个 32 位 数据 , 我们的程序可以通过 公钥 对 32 数据 还原 ,然后再通过我们写的 decrypt 进行 解密 .


这里主要是一个小功能, 可以将这个加密 放在我们的项目中 .

http://www.yayakq.cn/news/908026/

相关文章:

  • 个人网站建设简历低学历吃香的十大职业
  • 网站做百度竞价利于百度优化公司简介ppt模板素材
  • 网站建设中销售人员会问客户的问题潍坊制作网站公司
  • 郑州高端网站定制公共信息服务平台官网
  • 网站的黄金看盘软件网站服务器怎么收费
  • 网站首页适配规则成都 网站建设 app 开发
  • 免费建网站哪个模板多一个简单网页的代码
  • 电子商务网站建设与管理感想和收获免费网站建站排行榜
  • 必须在当地网站备案东莞视频网站制作
  • 建站模板 discuz游戏网站怎么做seo
  • 金山做网站建站时候源码有验证怎么办
  • 百度seo优化排名软件网站优化优化怎么做
  • 黄圃网站建设中高风险区域最新名单
  • 做设计在哪个网站上找高清图片岳阳建设局网站
  • 网站建站的尺寸seo诊断书案例
  • 网站一级域名和二级域名wordpress会员制
  • 龙岗网站建设哪家便宜深圳交易服务中心官网
  • j动态加载网站开发温州网站开发
  • 网站首页代码怎么写做汽车网可参考网站
  • 网站建设需求分析班级扁平化风格网站模板
  • 做线上网站的目的重庆建设工程交易中心
  • html5网站源码phppinthis wordpress
  • 东莞常平美食唐山网站关键词优化
  • 网站策划内容极品教师韩剧在线观看第一集
  • 杭州网站推广营销深圳网络推广服务是什么
  • 外贸网站建设服务器服务器iis添加网站
  • 江苏建筑网站什么样企业需要网站建设
  • app网站模板下载不了网站中常用的功能模块
  • 网站本身对网站打开速度有何影响珠海市网站建设公司
  • 龙岗在线网站制作郑州网站权重