php sha512 漏洞,PHP和Golang sha512的结果不同

我想在Golang中实现Symfony密码哈希.结果是同样期待一些角色.

Symfony解决方案:

function mergePasswordAndSalt($password, $salt)

{

return $password.'{'.$salt.'}';

}

$salted = mergePasswordAndSalt('asd12345', 'korsipcidz4w84kk0cccwo840s8s4sg');

$digest = hash('sha512', $salted, true);

for ($i = 1; $i < 5000; ++$i) {

$new = $digest.$salted;

$digest = hash('sha512', $new, true);

}

echo base64_encode($digest);

Golang解决方案:

package main

import (

"crypto/sha512"

"encoding/base64"

"fmt"

"hash"

)

var (

hasher hash.Hash

container []byte

)

func main() {

password := "asd12345"

salt := "korsipcidz4w84kk0cccwo840s8s4sg"

salted := []byte(password + "{" + salt + "}")

hasher = sha512.New()

hasher.Write(salted)

container = hasher.Sum(nil)

for i := 1; i < 5000; i++ {

new := append(container[:], salted[:]...)

hasher = sha512.New()

hasher.Write(new)

container = hasher.Sum(nil)

}

digest := base64.URLEncoding.EncodeToString(container)

fmt.Println(digest)

}

Golang结果:

yIp0074qTaxBz7fOGFpTVYU7LaAterUko6YjnmCZ55R6lAYouXWFoBKT_wI7Vit87RKbU9I-U3M2mU11v_KEUQ==

PHP结果:

yIp0074qTaxBz7fOGFpTVYU7LaAterUko6YjnmCZ55R6lAYouXWFoBKT/wI7Vit87RKbU9I+U3M2mU11v/KEUQ==

那么示例如何显示,它只是其他一些角色 – ,/,是不同的.我认为这可能是因为字符编码,但我不知道,我该如何判断它.

环境:Fedora 23,Go 1.7,PHP 5.6

解决方法:

你正在使用URLEncoding,而PHP似乎使用标准编码.更换

digest := base64.URLEncoding.EncodeToString(container)

digest := base64.StdEncoding.EncodeToString(container)

标签:php,base64,go,symfony

来源: https://codeday.me/bug/20190623/1266827.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值