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

如何实现基于 aes-ctr+s3 的中转加解密

  •  
  •   dzdh · 2023-07-05 21:13:45 +08:00 · 674 次点击
    这是一个创建于 500 天前的主题,其中的信息可能已经有所发展或是发生改变。

    想实现那种基于 s3 协议的网络存储加密后的视频文件流式还原成原本内容

    加密解密这么做的:

    func encode(buff []byte) []byte {
    	key := []byte("1234567887654321")
    	iv := bytes.Repeat([]byte("0"), 16)
    
    	block, _ := aes.NewCipher(key)
        stream := cipher.NewCTR(block, iv)
        
        encoded := make([]byte, len(buff))
        stream.XORKeyStream(encoded, buff)
        
        return encoded
    }
    
    // 加解密密一个文件
    readed, _ := open.ReadFile(test.mp4)
    
    encryptd := encode(readed)
    decrypted := encode(encrypted)
    

    测试经过加密再解密后的文件 能正常打开也不影响播放

    然后基于 http 这么写了个东西

    http.HandleFunc("/test.mp4", (w,r) {
    
        opened , _ := os.open("test.mp4")
        
        // cipher.StreamReader 没有实现 io.Seeker
        // 自己做了个 wrapper
        /*
        type myReader struct {
            cipher.StreamReader
        }
    
        func (reader *myReader) Seek(offset int64, whence int) (int64, error) {
            // os.open 返回的是 file ,是支持 seeker 的 streamreader 要求的接口是 io.reader
            return reader.R.(io.Seeker).Seek(offset, whence)
        }
        */
        
        key := []byte("1234567887654321")
    	iv := bytes.Repeat([]byte("0"), 16)
    	block, _ := aes.NewCipher(key)
        stream := cipher.NewCTR(block, iv)
        
        reader := &myReader{StreamReader:cipher.StreamReader{R:open, S:stream} }
        
        http.ServeContent(w,r,"test.mp4",time.Now(), reader)// 这个 reader 要求实现 io.Seeker
    
    })
    

    结果是播放一半直接不能播放了 显示视频时长是对的

    看了看别人家的实现。好复杂。。

    dzdh
        1
    dzdh  
    OP
       2023-07-07 08:58:04 +08:00
    已解决
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2594 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 15:41 · PVG 23:41 · LAX 07:41 · JFK 10:41
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.