首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
华为云
V2EX  ›  程序员

大家一般怎么生成盐的啊。。

  •  
  •   flowfire · 322 天前 · 8997 次点击
    这是一个创建于 322 天前的主题,其中的信息可能已经有所发展或是发生改变。

    nodejs 里用 crypto.randomBytes 生成一个 32 字节的随机数够不够。。
    以及密码 hash 就直接用 hamc(password, salt) 么 = = 啥算法比较好.。。sha256 够么= =

    65 回复  |  直到 2018-01-02 15:55:09 +08:00
        1
    thetast   322 天前 via Android   ♥ 12
    楼下超市买😁
        2
    kmdgeek   322 天前
    重结晶?(捂脸逃
        3
    bao3   322 天前 via iPhone   ♥ 7
    跑步后不要洗澡,大约 5 分钟得到盐
        4
    moult   322 天前 via iPhone
    盐么,没必要想那么复杂,随机来个 32 位的字符串差不多了。
    密码加密么,Symfony 做法是将密码和盐拼凑一起进行 SHA,然后将 SHA 的结果和密码和盐拼凑一起进行 SHA,就这样来个 5000 次。。。
        5
    dangyuluo   322 天前
    salt 有必要这么长么?看了一些系统的代码,4 位 8 位居多
        6
    yangqi   322 天前
    加盐并不能提高安全性
        7
    cnnblike   322 天前
    可以去 random.org 上生成的——但问题不在盐上,盐只是整个系统的一环,被攻破的时候最后出问题的往往不是盐而是一些愚蠢的设计。
        8
    flowfire   322 天前 via Android
    @yangqi ..... 为啥…………就算提高不了好歹也能防彩虹表吧

    @cnnblike 给用户生成盐还要调接口是不是太慢了一点
        9
    Torpedo   322 天前 via Android
    bcrypt 啊
        10
    mozutaba   322 天前 via Android   ♥ 2
    尿完不冲,自动结晶
        11
    phx13ye   322 天前
    建议 argon2,
    argon2.generateSalt().then(salt => {
    argon2.hash('some-user-password', salt).then(hash => {
    console.log('Successfully created Argon2 hash:', hash);
    // TODO: store the hash in the user database
    });
    });
        12
    justfindu   322 天前
    6-12 位 random 生成字母数字标点. 然而现在一般用 bcrypt
        13
    xomix   322 天前
    首先肯定要加个时间戳,然后你可以密码加用户名然后 md5 做盐,你还可以密码 md5 前 16 位加用户名 md5 后 16 位假装自己是 32 位 md5,加盐后验证奇数或偶数位的 md5 假装自己是动态 md516 位加密。(客户端随机传奇偶位,服务器端两种验证都做,有一种通过即可)
    让想逆推的人慢慢猜。
        14
    yilai   322 天前
    参考 django
        15
    dilu   322 天前
    加盐不如 bcrypt 虽然速度下来了 但是安全性能上去了
        16
    me1ody   322 天前
    如果密码简单在复杂的 salt 也是一样的,所以 salt 4-6 位即可
        17
    Cat73   322 天前
    @moult 我们项目还真差不多就这样的,用户的 ID 加随机 8 个字符当盐,盐+密码来一次 hash,然后 hash+密码继续 hash 上 pow(2, 8 + 3) 次,最后的密码是 3(hash 次数) + 盐(不含用户 ID 的部分) + hash
        18
    mcfog   322 天前 via Android
    配置的 secret/固定盐的话 openssl 命令生产,密码的话,不用自己手动生成盐,用类似 http://php.net/password_hash 的专用类库做这件事情,一个字段包含算法、盐、哈希,而且很容易支持 rehash,指定 cost 之类的
        19
    clino   322 天前
        20
    whx20202   322 天前   ♥ 1
    来来来看这个 http://blog.jobbole.com/61872/
    如果不懂建议无脑 bcrypt
        21
    shuizhengqi   322 天前
    我都是去超市买
        22
    ksupertu   322 天前 via iPhone
    bcrypt 啊,知乎都用的这个加 python:doge
        23
    icaca   322 天前
    🐶东搜竹盐
        24
    shihty5   322 天前
    抖机灵的都好无聊,第一个还算有点创意,后面的- -
        25
    sea516   322 天前
    去盐城
        26
    Reign   322 天前
    random
        27
    realpg   322 天前 via Android
    火碱兑醋精
        28
    f2f2f   322 天前
    $md5($md5($random+$timestamp)+$random)
    别告诉我你觉得这还不够
        29
    qnxu   322 天前
    @bao3 谁都不服就服你
        30
    Doodlister   321 天前 via Android
    shiro。
        31
    geelaw   321 天前
    看了上面一些回复,很有“保存 100 遍确保保存成功”的代码的感觉。
        32
    zythum   321 天前
    一般用 pm 的名字当盐
        33
    hcnhcn012   321 天前 via iPhone
    2Na + Cl2 === 2NaCl
        34
    Livid   V2EX Moderator   321 天前
    上面发布无意义跑题回复的账号已经全部被 Deactivate。
        35
    raofeng   321 天前
    我们也用的 bcrypt
        36
    we000   321 天前   ♥ 4
    @Livid 这样的操作应该越少越好, 威权用得越多大家越反感. 我个人对你管理社区的不满全来自于此, 当然你的地盘你说了算, 我也还是喜欢换小号过来晃.

    这个帖子我觉得一部分原因是因为标题, 如果标题写好"算哈希的时候怎么生成盐", 估计没人会抖机灵.
        37
    suspended   321 天前
    某些人以为多次 hash 能增强安全性,笑死人了。
        38
    flowfire   321 天前
    @suspended #37 我以前也是这么以为的 [捂脸
        39
    yorath   321 天前
    看标题以为大家用的盐都是自己生成的 不是超市买来的....
        40
    SingeeKing   321 天前
    @suspended 哎难道不是吗。。
        41
    ThatIsFine   321 天前
    @SingeeKing 就是一定长度的字符串而已, 它自己再怎么算也没多大作用.

    创建一般是输入一个口令, 经过加密算法, 再搞一个随机串(盐)合并, 最后再加密, 盐和最后的串存数据库, 每次鉴权会再使用盐和输入算最后的串.
    通过彩虹表撞库, 一般是已知算法, 生成数据字典, 去直接撞最后的串.
        42
    ligo   321 天前 via Android
    酸碱中和
        43
    ligo   321 天前 via Android
    怎样删除回复??盐只要无法预测就可以了
        44
    ligo   321 天前 via Android
    我又想了一下,盐可以预测也无所谓,只要每个用户的盐值不同就行
        45
    geelaw   321 天前 via iPhone
    @SingeeKing
    @ThatIsFine
    @flowfire
    @suspended

    多次 hash 唯一可能增加安全性的可能是让 hash 计算变慢,然而这个和盐没什么关系。而且区区那么几次也没太大作用,我也不太懂为什么他们要,比如,hash 5000 次之类的。
        46
    suspended   321 天前
    @geelaw 并没有。实际上是增加了自己系统的计算量,减少了攻击者的计算量,降低了系统安全性的。
        47
    geelaw   321 天前 via iPhone
    @suspended 没明白,攻击者拖库之后想要算出一个可以通过系统验证的密码是需要自己算了 hash 的。没有明白这怎么减少了攻击者的计算量。

    注意语境:加盐是为了防止拖库之后攻击者能用彩虹表或者频率统计的方法获取密码,这里的手法都是为了阻碍拖库之后得到密码的。
        48
    l1093178   321 天前
    每个用户盐不一样,而且盐足够长就行了,对随机性没什么要求...
    以及记得选个慢 hash 函数(比如 argon2,scrypt 或者 bcrypt,安全性依序降低),md5 和 SHA 系列 hash 函数都不安全(用 GPU / 专用硬件破解起来很快)

    @suspended 然而多次 hash 确实能提高破解的成本,当然新的密码 hash 函数都直接把 cost 设置为 hash 函数的一个参数了。
        49
    chinvo   321 天前
    @geelaw 随机输入计算一次,输入是不定长的,但是多次计算,相当于拿最后那个定长字符串去算一次。
        50
    msg7086   321 天前
    @geelaw 前提是源码不泄露?

    @flowfire 生成随机数直接用语言运行时自带的就好了。
    Java 和 Ruby 用 SecureRandom,PHP 可以用 random_bytes 这些。
        51
    geelaw   321 天前
    @chinvo #49 并不是这样的,攻击者的目标是找到一个字符串作为密码输入系统的时候可以通过验证,譬如系统要求

    hash1(hash2(input)) == saved_hash

    并不是说找到了 found=hash2(password) 就可以的——目标是解方程 hash1(hash2(x)) = y,而 x=found 并不是一个解。注意:这两个 hash 都是在服务器算的,在客户端算的已经被建模为 input 了。

    @msg7086 #50 不知道您回复的是哪一层,不过无论如何,安全的系统不怕代码泄露。
        52
    msg7086   321 天前
    @geelaw 我重新读了 3 遍回复,感觉你,我,和 @suspended 互相有些上下文上的误解……

    suspended 同意了你的观点,你反对了他的观点,我同意了 suspended 的观点,然后反对了你的观点,又同意了你之前的观点。
        53
    suspended   321 天前
    @geelaw 恩,我的说法不对,没有考虑位数带来的计算量指数级增长,只考虑了 hash 结果的字符集是可预测的范围。
        54
    geelaw   321 天前
    @msg7086 #52

    我 #31:不需要多次 hash
    suspended #37:多次 hash 不能增强安全性(同意我)
    我 #45:(回复 #37 )多次 hash **有时**可以通过增加计算 hash 的难度增加安全性,但是这种方法和“盐”的主题没关系
    suspended #46:(我认为是回复 #45 )多次 hash 会降低安全性
    我 #47:(回复 #46 )没明白 #46
    您 #50:(不知道回复哪一层)

    我在 #31 表示不需要多次 hash 是说就盐这个机制,而且使用专门设计的慢 hash 更好;此外,我觉得是“保存 100 次”的另一个原因是,我没看出来他们这样做是为了减慢速度,那些发言给我的感觉是单纯觉得多加几次 hash 更难。

    完整来说,我的观点:

    - 增加(固定次数的) hash 次数等价于改变 hash 函数,并不会让破解更困难(除了可能会让 hash 计算更慢这方面)
    - 加盐是为了让每个用户用不同的 hash 函数,从而无效化彩虹表和频率统计
        55
    msg7086   321 天前
    @geelaw 你的观点没错。
    我是想说多次 hash 只要源码和数据库一起泄露就无效了,不能提高安全性。
    你 47 没明白 46,所以我 50 也一眼没看明白 47。
        56
    geelaw   321 天前
    @msg7086 但我还是没理解怎么会“降低安全性”。
        57
    msg7086   321 天前
    @geelaw

    suspended 1 小时 40 分钟前
    并没有。 [将专业的加盐 Hash 替换为多次反复计算 Hash,]实际上是增加了自己系统的计算量,减少了攻击者的计算量,降低了系统安全性的。
        58
    sgissb1   321 天前
    超市或者小卖铺买一包,接着倒出来,就生成盐了。这是最安全的。

    科学宅的做法,一般是买一瓶氢氧化钠,接着买点盐酸,按照一摩尔氢氧化钠和一摩尔盐酸的比例用滴注法一点点的混合,在混合过程中需要用烧瓶作为容器,且需要注意温度变化,带滴注完成后,用玻璃棒轻微的搅拌调匀,即可得到
    生成 的氯化钠,也就是我们百姓口中说的不加典食盐的主要成分。
        59
    geelaw   321 天前
    @msg7086 get 这个意思了,但是前面反复 hash 很多次的人也都加了盐,所以没想到这个省略的意思。
        60
    kmahyyg   321 天前 via Android
    python3.6

    secrets.token_urlsafe(16)
        61
    youyoulemon   321 天前
    @sgissb1 呆子才会用昂贵的氢氧化钠、盐酸反应#滑稽
        62
    ligo   321 天前 via Android
    @l1093178 我的理解对不对
    1.加盐的本质是增加密码的有效长度
    2.不同的盐之间尽量不要有公共子序列
    3.hash 破解难度随长度指数增长
        63
    sgissb1   321 天前
    @youyoulemon 我觉得氢氧化钠不贵啊,莫非我记错了?
        64
    sgissb1   321 天前
    @youyoulemon 打错字了,我不是觉得,我是记得!
        65
    lzx728   316 天前
    @Livid 如何合并账号或注销某个账号? https://www.v2ex.com/t/418578
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3367 人在线   最高记录 3821   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.1 · 24ms · UTC 03:42 · PVG 11:42 · LAX 19:42 · JFK 22:42
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1