Python:# generate passwordldap_salted_md5.hash("123456") # verify passwordldap_salted_md5.verify("123456","{SMD5}991RjK3DQCT+ri/yxQB613Yuxdg=")# return true壳:# generate passwordslappasswd -h {SMD5} -s "123456" # return {SMD5}ZmDHoIiZZG/weuCNkLj189sFoPM=# verify password by python ldap_salted_md5.verify("123456","{SMD5}ZmDHoIiZZG/weuCNkLj189sFoPM=")# return True我想用go来实现ldap_salted_md5.verify这一步
1 回答

叮当猫咪
TA贡献1776条经验 获得超12个赞
saltPassword := strings.Replace(user.Password, "{SMD5}", "", -1)
decodeSaltPassword, _ := base64.StdEncoding.DecodeString(saltPassword)
checksum := decodeSaltPassword[0:16]
salt := decodeSaltPassword[16:]
md5Ctx := md5.New()
md5Ctx.Write([]byte(bindSimplePw))
md5Ctx.Write(salt)
cipherStr := md5Ctx.Sum(nil)
if !bytes.Equal(checksum, cipherStr) {
return ldap.LDAPResultInvalidCredentials, nil
}
- 1 回答
- 0 关注
- 97 浏览
添加回答
举报
0/150
提交
取消