V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
body007
V2EX  ›  Go 编程语言

EncryptionFile 发布 v1.0.7 版本,支持标准库 cipher 的全部 3 中加密算法接口

  •  
  •   body007 · 236 天前 · 586 次点击
    这是一个创建于 236 天前的主题,其中的信息可能已经有所发展或是发生改变。

    项目地址: https://github.com/jan-bar/EncryptionFile

    之所以更新这一版,是因为有人觉得上个版本中只用到aes cfb这种流式加密算法不安全,他们希望用更安全的aes gcm加密方式。因此我看了 go 标准库支持cipher.AEAD ,cipher.Stream ,cipher.BlockMode这三种加密接口,因此这一版本直接支持这三种接口。用户还可以自定义加解密方案,只要是上面三种接口类型就可以实现数据安全加解密。

    你也可以用我内置的 EncryptionFile.GenEncCipher ,EncryptionFile.GenDecCipher 这两个方法轻松实现指定加密算法,如下所示。

    当然你也可以自己写方法,只要实现cipher.AEAD ,cipher.Stream ,cipher.BlockMode这三种接口就行。

    // an encryption scheme can be specified with the built-in method
    // GenEncCipher(cipher.NewCFBEncrypter)
    // GenEncCipher(cipher.NewCTR)
    // GenEncCipher(cipher.NewOFB)
    // GenEncCipher(cipher.NewCBCEncrypter)
    // GenEncCipher(cipher.NewGCM)
    EncData(Reader, Writer, pubKey, md5.New(), GenEncCipher(cipher.NewCFBEncrypter))
    
    // an decryption scheme can be specified with the built-in method
    // GenDecCipher(cipher.NewCFBDecrypter)
    // GenDecCipher(cipher.NewCTR)
    // GenDecCipher(cipher.NewOFB)
    // GenDecCipher(cipher.NewCBCDecrypter)
    // GenDecCipher(cipher.NewGCM)
    DecData(Reader, Writer, priKey, md5.New(), GenDecCipher(cipher.NewCFBDecrypter))
    

    可用学习单元测试 TestCipher,掌握这个库的用法。

    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1993 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 01:09 · PVG 09:09 · LAX 18:09 · JFK 21:09
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.