Go 利用OpenSSL 实现md5-sha1计算方法
在计算机网络上,OpenSSL是一个开放源代码的软件库包,应用程序可以使用这个包来进行安全通信,避免窃听,同时确认另一端连线者的身份。这个包广泛被应用在互联网的网页服务器上。
其主要库是以C语言所写成,实现了基本的加密功能,实现了SSL与TLS协议。OpenSSL可以运行在OpenVMS、 Microsoft Windows以及绝大多数类Unix操作系统上(包括Solaris,Linux,Mac OS X与各种版本的开放源代码BSD操作系统)。
代码:
package main
/*
#cgo CFLAGS: -I ./include
#cgo LDFLAGS: -L ./lib -lcrypto -ldl
#include <stdlib.h>
#include <openssl/evp.h>
#include <openssl/md5.h>
*/
import "C"
import (
"fmt"
"os"
"unsafe"
)
func main() {
strdigestname := "md5-sha1"
strdata := "https://const.net.cn/"
digestname := []byte(strdigestname)
md := C.EVP_get_digestbyname((*C.char)(unsafe.Pointer(&digestname[0])))
if md == nil {
fmt.Printf("Unknown message digest %s\n", strdigestname)
os.Exit(1)
}
md_value := make([]byte, 128)
md_len := 0
data := []byte(strdata)
mdctx := C.EVP_MD_CTX_new()
C.EVP_DigestInit(mdctx, md)
C.EVP_DigestUpdate(mdctx, unsafe.Pointer(&data[0]), C.size_t(len(data)))
C.EVP_DigestFinal_ex(mdctx, (*C.uchar)(unsafe.Pointer(&md_value[0])), (*C.uint)(unsafe.Pointer(&md_len)))
C.EVP_MD_CTX_free(mdctx)
fmt.Printf("message digest=%x %s message digest len=%d\n", md_value[0:md_len], strdigestname, md_len)
}
输出:
go run .
message digest=4b655b565c09136dd867a7e523371391405036731104eeb5fae59f5f600f8b4771d93ac5 md5-sha1 message digest len=36
echo -n "https://const.net.cn/" |openssl dgst -md5-sha1
(stdin)= 4b655b565c09136dd867a7e523371391405036731104eeb5fae59f5f600f8b4771d93ac5
本文链接地址:https://const.net.cn/73.html