go - 使用 golang 生成有效的 dkim 密钥
问题描述
我正在尝试使用 golang 生成 dkim 密钥,我当前的代码是:
import (
"crypto/rand"
"crypto/rsa"
"crypto/x509"
"encoding/asn1"
"encoding/gob"
"encoding/pem"
"fmt"
"os"
)
func Keymaker(path string) {
reader := rand.Reader
bitSize := 2048
key, err := rsa.GenerateKey(reader, bitSize)
checkError(err)
publicKey := key.PublicKey
//saveGobKey("private.key", key)
savePEMKey(path+".priv", key)
//saveGobKey("public.key", publicKey)
savePublicPEMKey(path+".pub", publicKey)
}
func savePEMKey(fileName string, key *rsa.PrivateKey) {
outFile, err := os.Create(fileName)
checkError(err)
defer outFile.Close()
var privateKey = &pem.Block{
Type: "PRIVATE KEY",
Bytes: x509.MarshalPKCS1PrivateKey(key),
}
err = pem.Encode(outFile, privateKey)
checkError(err)
}
func savePublicPEMKey(fileName string, pubkey rsa.PublicKey) {
asn1Bytes, err := asn1.Marshal(pubkey)
checkError(err)
var pemkey = &pem.Block{
Type: "PUBLIC KEY",
Bytes: asn1Bytes,
}
pemfile, err := os.Create(fileName)
checkError(err)
defer pemfile.Close()
err = pem.Encode(pemfile, pemkey)
checkError(err)
}
func checkError(err error) {
if err != nil {
fmt.Println("Fatal error ", err.Error())
os.Exit(1)
}
}
代码正在运行,生成 dkim 私钥/公钥,问题是此密钥由发件人返回错误密钥,如果我使用此站点生成密钥:https ://easydmarc.com/tools/dkim-record-generator/密钥结果有效的。
这是我在 dns 中的 dkim 设置:
v=DKIM1;t=s;p=MIGJAoGBD1DSPRFFTujiCAiadP9ZeA6eAyf0GktfCQO2WKbrAx2Cu15y2A+agQMWNTmZbbhcznGZiz3kA9y7c0wOqN2iaJchBAxt4qdg1vUhy+6CkSZcY5bdm8uOxsXW3gjOTyZrOur/c118wMTOmSJKHOjn9xLG3ta8tXJtqab8idtx4TlBAgMBAAE=
我试图理解由 easydmarc.com 生成的方式键工作,而 golang 键不工作。有什么想法吗?
解决方案
推荐阅读
- node.js - Express(NodeJS)更多内核与更多节点?(附分析和实例)
- arrays - C中的字符数组空终止和长度
- angular - 如何在 Angular9 中使用激活的路由过滤 api 响应?
- ruby-on-rails - rails 6中的强大参数问题
- c# - 单击被测试的方法(在测试类中)重定向到元数据控制器而不是原始 mvc 控制器(在 .net 中)。怎么修?
- macos - 有没有办法在 macOS 中读取 .env 文件?
- python - 将点列表转换为 SVG 三次分段贝塞尔曲线
- ios - iCloud 仪表板:无法将 CloudKit 架构部署到生产环境
- php - 分类过滤器的 show_option_all 数组设置
- python - 旋转单个 Kivy 元素