java - 需要一个加密,验证算法

 讨厌上学的-彭志超-_354 发布于 2022-10-25 11:09

/**
获取随机密码
date的格式是年月日yymmdd,privatyKey为10位左右的字母数字组合串
1.需要返回8位纯数字
2.须使用date,privatyKey来生成
3.每次调用都是随机生成的(在date、privatyKey相同的情况下,返回的结果也要不同),尽量保证低重复率
**/
getPassword(date,privatyKey){

}

/**
检测密码
getPassword生成的密码可以通过检测,随便输入的密码通不过检测
**/
checkPassword(date,privatyKey,password){

}

有什么合适的算法?

6 个回答
  • 最终的方案取hash后的一部分值

    2022-10-26 23:24 回答
  • md5,openssl的比较简单

    2022-10-26 23:24 回答
  • 如果要返回结果每次都不一样的话可以采用TripleDes

    但是结果只能是8位纯数字,这个就够呛了

    2022-10-26 23:24 回答
  • 用MD5试试

    2022-10-26 23:24 回答
  • 可以用一个现成的哈希函数(比如sha256)作用在(date, pkey)上。结果一般远超出8位纯数字的信息。把这些信息分割成小段随机返回一段。

    getpass(date, pkey) {
      passwords[10] = sha256(date, pkey);
      return passwords[random(1,10)];
    }
    
    checkpass(date, pkey, pass) {
      passwords[10] = sha256(date, pkey);
      return (pass in passwords);
    }
    2022-10-26 23:24 回答
  • 1. 从date和privateKey生成一个单向函数,如 `f(num) = SHA256(num ++ date ++ privateKey)` (++表示字符串拼接)
    2. 随机生成一个3位数字a, 计算 `b = f(a)`
    3. 取 `c = b中的前5位数字`, 返回 `a ++ c`

    绕不过去的问题: 8位数字 (1e8 或 2^30) 能放的东西太少了。
    所以这个做法几乎完全不抗穷举,攻击者只需固定前3位穷举后5位。
    用的时候必须对算法本身保密,或加上尝试次数等限制。


    一个略微增加穷举难度的变体:

    2. 第一次生成时返回f(1)的前8位数字 第二次生成时返回f(2)的前8位, ...
    3. 检验时生成f(1) ~ f(100),检查输入是否属于这个集合
    2022-10-26 23:25 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有