douchengchu8374 2016-10-22 08:47
浏览 55
已采纳

用多重写入器计算加密数据的哈希

I was hoping to be able to calculate the hash of the encrypted data in parallel, but it seems like using a multiple writer as below, the hash is being calculate with plaintext bytes.

Anyone know how I can use a single copy to achieve both encrypting the data and hashing it?

    writer := &cipher.StreamWriter{S: cipher.NewCTR(block, iv), W: writeFile}
    writeFile.Write(iv)

    if _, err := io.Copy(io.MultiWriter(writer, hash), readFile); err != nil {
        fmt.Println("error during crypto: " + err.Error())
        return "", err
    }
  • 写回答

1条回答 默认 最新

  • dongtou8736 2016-10-22 11:24
    关注

    You need to move your io.MultiWriter to be the writer of the cipher.StreamWriter. This will calculate the hash of the cypher text, rather than plain text:

    writer := &cipher.StreamWriter{
        S: cipher.NewCTR(block, iv),
        W: io.MultiWriter(writeFile, hash),
    }
    writeFile.Write(iv)
    
    if _, err := io.Copy(writer, readFile); err != nil {
        fmt.Println("error during crypto: " + err.Error())
        return "", err
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序
  • ¥15 多址通信方式的抗噪声性能和系统容量对比
  • ¥15 winform的chart曲线生成时有凸起
  • ¥15 msix packaging tool打包问题
  • ¥15 finalshell节点的搭建代码和那个端口代码教程
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作