首页 > 编程语言 > 详细

GO语言密码加解密(bcrypt)

时间:2021-06-04 01:21:17      阅读:25      评论:0      收藏:0      [点我收藏+]

bcrypt加密算法介绍
bcrypt算法对于同一个密码,每次生成的hash不一样

业务流程

对用户注册时传入的密码进行加密
//此方法生成hash值

HashAndSalt([]byte("password"))     //password为string类型

将第一次生成的密码hash值存入数据库

密码验证

hashedPwd为保存在数据库中的密码hash,password为前端传过来要验证的密码
ComparePasswords 方法返回true说明密码验证通过

ValidatePasswords(hashedPwd string,[]byte("password"))      

封装加密和验证方法

package utils

import (
    "golang.org/x/crypto/bcrypt"
)

// 加密密码
func HashAndSalt(pwd []byte) string {
    hash, err := bcrypt.GenerateFromPassword(pwd, bcrypt.MinCost)
    if err != nil {

    }
    return string(hash)
}

// 验证密码
func ValidatePasswords(hashedPwd string, plainPwd []byte) bool {
    byteHash := []byte(hashedPwd)
    err := bcrypt.CompareHashAndPassword(byteHash, plainPwd)
    if err != nil {
        return false
    }
    return true
}
链接:http://events.jianshu.io/p/156bed22328f

GO语言密码加解密(bcrypt)

原文:https://www.cnblogs.com/hsyw/p/14847693.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!