go-cryptobin 常用加密解密库,v1.0.1030 发布并且添加 openssh 证书生成和解析

tuzhiya · 2022-09-02 00:04:00 · 1843 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2022-09-02 00:04:00 的主题,其中的信息可能已经有所发展或是发生改变。

go-cryptobin 是一个 go 的常用加密解密库,包含了一下特性

  • go-cryptobin 包括常用的对称加密和非对称加密及签名验证
  • 对称加密解密(Aes/Des/TriDes/SM4/Tea/Twofish/Xts)
  • 对称加密解密模式(ECB/CBC/CFB/OFB/CTR/GCM)
  • 对称加密解密补码(NoPadding/ZeroPadding/PKCS5Padding/PKCS7Padding/X923Padding/ISO10126Padding/ISO97971Padding/ISO7816_4Padding/TBCPadding/PKCS1Padding)
  • 非对称加密解密(RSA/SM2)
  • 非对称签名验证(RSA/PSS/DSA/Ecdsa/EdDSA/SM2)
  • 默认 Aes, ECB, NoPadding
  • 项目地址: https://github.com/deatil/go-cryptobin

最新版本添加了 openssh 证书生成和解析,具体使用可以看一下示例

  • ssh rsa生成使用
package main

import (
    "fmt"
    "encoding/pem"
    "github.com/deatil/lakego-filesystem/filesystem"
    cryptobin_ssh "github.com/deatil/go-cryptobin/ssh"
    cryptobin_rsa "github.com/deatil/go-cryptobin/cryptobin/rsa"
)

func main() {
    fs := filesystem.New()

    rsa := cryptobin_rsa.NewRsa().GenerateKey(2048)

    // block, _ := cryptobin_ssh.MarshalOpenSSHPrivateKey(obj.GetPrivateKey(), "comment")
    // block, _ := cryptobin_ssh.MarshalOpenSSHPrivateKeyWithPassword(obj.GetPrivateKey(), "comment", []byte("123"))
    rsaBlock, _ := cryptobin_ssh.MarshalOpenSSHPrivateKeyWithPassword(
        rsa.GetPrivateKey(),
        "comment",
        []byte("123"),
        cryptobin_ssh.Opts{
            // cryptobin_ssh.AES256CBC
            Cipher:  cryptobin_ssh.AES256CTR,
            KDFOpts: cryptobin_ssh.BcryptOpts{
                SaltSize: 16,
                Rounds:   16,
            },
        },
    )

    rsaBlockkeyData := pem.EncodeToMemory(rsaBlock)
    fs.Put("./runtime/key/ssh/rsa-en", string(rsaBlockkeyData))

    fmt.Println("生成成功")
}

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1843 次点击  
加入收藏 微博
2 回复  |  直到 2022-09-03 23:19:33
xuwentao
xuwentao · #1 · 3年之前

给力,居然支持openssl

tuzhiya
tuzhiya · #2 · 3年之前
xuwentaoxuwentao #1 回复

给力,居然支持openssl

openssl 相关的加解密一直有的。现在是加的 openssh key的生成和解密,开始标题写错了,首页的缓存还没有更新过来

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传