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

怎么用nat做网站企业网站建设报价表

怎么用nat做网站,企业网站建设报价表,网站地图制作工具,移动wap是什么意思一、MD5 加密算法 MD5(Message Digest Algorithm 5)是一种常用的哈希函数,用于将任意长度的数据进行不可逆的加密处理。MD5 可以将输入的任意长度的数据转换为一个128位(16字节)的哈希值,通常表示为32个十…

一、MD5 加密算法

MD5(Message Digest Algorithm 5)是一种常用的哈希函数,用于将任意长度的数据进行不可逆的加密处理。MD5 可以将输入的任意长度的数据转换为一个128位(16字节)的哈希值,通常表示为32个十六进制数字。

MD5 的特点

  1. 不可逆性:MD5 加密是不可逆的,即无法从加密后的结果还原出原始数据。
  2. 固定长度输出:不论输入数据的长度如何,MD5 始终输出固定长度的哈希值
  3. 高速度:MD5 的计算速度较快。

虽然MD5能够对数据加密,但已被证明存在多种破解方式。常见的破解方法有彩虹表攻击碰撞攻击。所以不建议单独使用 MD5 进行加密。

彩虹表攻击: 彩虹表是一种预计算的哈希值与明文密码的映射表。攻击者通过比对MD5哈希值与彩虹表中的条目,快速找到对应的明文。

碰撞攻击:MD5易受碰撞攻击,即两个不同的输入(如文本、密码)生成相同的哈希值。攻击者可以构造特定数据,生成与目标哈希值相同的伪造数据。如果输入的信息得到的哈希值与密码的哈希值相同,那么这个密码就别破解了。

因此会将数据进行加盐加密,加盐加密是一种增强密码存储安全性的技术,通过为每个用户的密码添加一个随机字符串(称为“盐”),再对组合后的字符串进行哈希处理。这种方法可以有效防止彩虹表攻击和字典攻击。

盐值通常是一个随机的、唯一的字符串,与密码拼接后再进行哈希运算。例如:

  • 原始密码:password123
  • 盐值:a1b2c3d4
  • 加盐后输入:password123a1b2c3d4
  • 哈希结果:哈希函数(password123a1b2c3d4)

加盐的优势

  • 即使两个用户使用相同的密码,由于盐值不同,哈希结果也不同。
  • 攻击者无法直接使用预计算的彩虹表,因为盐值增加了破解难度。

二、加盐加密算法

加密思路

盐值(唯一的字符串,可用UUID 生成) +  数据 (MD5 加密后的数据) = 最终存入数据库的加密数据

验证数据思路

  1. 获取数据库加密数据
  2. 取出加密数据的盐值
  3. 盐值 + 待验证数据(MD5 加密后)=  待验证数据最终结果
  4. 待验证数据 与 数据库中的加密数据对比,相等则是正确的,否则是错误的
package com.kjz.utils.common;import org.springframework.util.DigestUtils;
import org.springframework.util.StringUtils;import java.util.UUID;public class PasswordUtils{/*** 1.加盐并生成最终的密码* @param password 明文的密码* @return 最终生成的密码*/public static String encrypt(String password){//a.产生盐值//UUID.randomUUID()会生成32位数字+4位-,是随机的唯一的,将4位-去掉就得到32位数字的盐值String salt = UUID.randomUUID().toString().replace("-","");//生成加盐后的密码(需要使用MD5)String saltPassword = DigestUtils.md5DigestAsHex((salt + password).getBytes());//返回最终的密码格式return salt + "$" + saltPassword;}/*** 2.加盐并生成最终密码格式(方法一的重载),区别于上面的方法:这个方法是用来解密的,给定了盐值,生成一个最终密码,后面要和正确的最终密码进行比对* @param password 需要验证的明文密码* @param salt* @return*/public static  String encrypt(String password, String salt){//1.生成一个加密后的密码String saltPassword = DigestUtils.md5DigestAsHex((salt + password).getBytes());//2.生成最终的密码(待验证)String finalPassword = salt + "$" + saltPassword;return finalPassword;}/*** 3.验证密码* @param inputPassword  登录用户输入的明文密码* @param finalPassword  数据库中实际的最终密码格式* @return*/public static boolean check(String inputPassword, String finalPassword){//首先判断这两个参数到底有没有值,数据库中的最终密码是不是65位if(StringUtils.hasLength(inputPassword) && StringUtils.hasLength(finalPassword)&& finalPassword.length() == 65){//a.首先从最终的密码中得到盐值//使用$将finalPassword划分成两个部分,前面的32位的部分就是盐值//注意:这里的$是被认为是一个通配符,所以要转义一下String salt = finalPassword.split("\\$")[0];//b.使用之前加密的方法,生成最终的密码格式(待验证)String checkPassword = encrypt(inputPassword,salt);if(checkPassword.equals(finalPassword)){return true;}}return false;}
}

 

 

http://www.hkea.cn/news/654672/

相关文章:

  • 东莞有什么比较好的网站公司苏州关键词排名系统
  • 做中国供应商免费网站有作用吗浙江网站推广运营
  • mysql8 wordpress百度推广优化是什么意思
  • 做装修广告网站好seo推广公司招商
  • 城市模拟建设游戏网站今天最新的新闻头条新闻
  • 手机网站自适应代码品牌网络营销策划方案
  • 个人网站建设在哪里百度资源搜索平台
  • 云空间免费空间北京网站优化校学费
  • 个人网站做导航网站项目推广平台有哪些
  • 威海住房建设局网站培训学校资质办理条件
  • 做趣味图形的网站免费线上培训平台
  • 女生做网站前端设计师成都网站seo
  • 濮阳建设银行官方网站搜索引擎优化的对比
  • 完全删除wordpressseo小白入门
  • 做网站常用到的css标签什么软件可以找客户资源
  • 有做销售产品的网站有哪些新闻头条今日新闻
  • 深圳自己做网站 服务器优化的近义词
  • 网站开发职业工资网站推广上首页
  • 宝安附近公司做网站建设多少钱深圳百度开户
  • 成都紧急通知seo网络营销招聘
  • 思坎普网站建设如何做营销推广
  • 太原网站优化公司有域名和服务器怎么建网站
  • 网站策划的前景seo 推广
  • wordpress导入网站文章怎么联系百度人工客服
  • 制冷机电工程东莞网站建设简阳seo排名优化培训
  • 北京网站建设 网站维护服装营销方式和手段
  • 唐山高端网站建设开发新客户的十大渠道
  • 小地方的旅游网站怎么建设seo教程有什么
  • 做网站教程宁波百度seo点击软件
  • asp.net个人网站北京专门做seo