crypto/sha1
sha1包
import "crypto/sha1"
- 概述
- 索引
- 示例
概述
sha1 包实现了 RFC 3174 中定义的 SHA-1 哈希算法。
SHA-1 密码破坏,不应用于安全应用程序。
索引
- 常量
- func New() hash.Hash
- func Sum(data []byte) [Size]byte
示例
New New (File) Sum
文件包
sha1.go sha1block.go sha1block_amd64.go
常量
SHA-1 的块大小(以字节为单位)。
const BlockSize = 64
SHA-1 校验和的大小(以字节为单位)。
const Size = 20
func New(查看源代码)
func New() hash.Hash
New 返回一个新的 hash.Hash 计算 SHA1 校验和。
示例
package main
import (
"crypto/sha1"
"fmt"
"io"
)
func main() {
h := sha1.New()
io.WriteString(h, "His money is twice tainted:")
io.WriteString(h, " 'taint yours and 'taint mine.")
fmt.Printf("% x", h.Sum(nil))
}
示例(File)
package main
import (
"crypto/sha1"
"fmt"
"io"
"log"
"os"
)
func main() {
f, err := os.Open("file.txt")
if err != nil {
log.Fatal(err)
}
defer f.Close()
h := sha1.New()
if _, err := io.Copy(h, f err != nil {
log.Fatal(err)
}
fmt.Printf("% x", h.Sum(nil))
}
func Sum(查看源代码)
func Sum(data []byte) [Size]byte
总和返回数据的 SHA-1 校验和。
示例
package main
import (
"crypto/sha1"
"fmt"
)
func main() {
data := []byte("This page intentionally left blank.")
fmt.Printf("% x", sha1.Sum(data))
}