Go:XORKeyStream():运行时错误:无效的内存地址或零指针取消引用

标签 go null

当我尝试运行以下代码时(我尝试在 CFB 模式下使用 AES 加密字符串的字节数组表示形式)我收到一个无效内存地址或零指针取消引用错误,在 sEnc.XORKeyStream(msgB, msgB) 行上。文档说 XORKeyStream 的源和目标可以是相同的字节数组(也尝试使用单独的目标,但没有骰子),但我无法弄清楚是什么导致了错误。我在 OS X Lion 上使用最新版本的 Go App Engine SDK。

由于此时我仍在尝试获取代码以简单地加密某些东西,我只是生成一个随 secret 钥而不是存储它。

func generateKey(w http.ResponseWriter, r *http.Request) {
    key := make([]byte, 32)
    n, err := rand.Read(key)
    err = err
    if(err != nil) {
        fmt.Fprint(w, err)
        return
    }
    if(n != 32) {
        fmt.Fprint(w, "Not enough bytes read.")
        return
    }
    c, err := aes.NewCipher(key)
    if(err != nil) {
        fmt.Fprint(w, err)
    }

    iv := make([]byte, 32)
    n, err = rand.Read(iv)
    err = err
    if(err != nil) {
        fmt.Fprint(w, err)
        return
    }
    if(n != 32) {
        fmt.Fprint(w, "Not enough bytes read.")
        return
    }

    sEnc := cipher.NewCFBEncrypter(c, iv)

    msg := "text to be encrypted"
    msgR := strings.NewReader(msg)
    msgB := make([]byte, msgR.Len())
    n, err = msgR.Read(msgB)
    if(err != nil) {
        fmt.Fprint(w, err)
        return
    }
    if(n == 0) {
        fmt.Fprint(w, "No bytes read.")
        return
    }
    fmt.Fprint(w, msgB)
    fmt.Fprint(w, "<br>")
    sEnc.XORKeyStream(msgB, msgB)
    fmt.Fprint(w, msgB)
}

错误信息:

2011/08/15 15:15:58 http: panic serving : runtime error: invalid memory address or nil pointer dereference runtime.panic /private/tmp/appengine/google_appengine/goroot/src/pkg/runtime/proc.c:1041 runtime.panicstring /private/tmp/appengine/google_appengine/goroot/src/pkg/runtime/runtime.c:116 runtime.sigpanic /private/tmp/appengine/google_appengine/goroot/src/pkg/runtime/darwin/thread.c:470 server.generateKey server/server.go:66 http.HandlerFunc·ServeHTTP /private/tmp/appengine/google_appengine/goroot/src/pkg/http/server.go:589 http.*ServeMux·ServeHTTP /private/tmp/appengine/google_appengine/goroot/src/pkg/http/server.go:790 appengine_internal.handleFilteredHTTP /private/tmp/appengine/google_appengine/goroot/src/pkg/appengine_sdk/go_appengine_sdk/appengine_internal/api_dev.go:58 http.HandlerFunc·ServeHTTP /private/tmp/appengine/google_appengine/goroot/src/pkg/http/server.go:589 http.*conn·serve /private/tmp/appengine/google_appengine/goroot/src/pkg/http/server.go:555 runtime.goexit /private/tmp/appengine/google_appengine/goroot/src/pkg/runtime/proc.c:178 INFO 2011-08-15 15:15:58,310 dev_appserver.py:4248] "GET /genkey/aes256 HTTP/1.1" 500 -

我已经发布了 the rest of the code粘贴 bin,但这只是 includes/init 函数,没什么有趣的。

最佳答案

由于错误,

sEncnil。对于 cipher.NewCFBEncrypter , "iv 必须与 Block 的 block 长度相同。"AES block 大小是 128 位还是 16 字节?例如,

iv := make([]byte, c.BlockSize())

关于Go:XORKeyStream():运行时错误:无效的内存地址或零指针取消引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7066801/

相关文章:

C# LINQ NULL 检查

sql - 为什么 "Null Like X"和 "Not (Null Like X)"相等?

java - 删除包含 null 的字符串

c# - 如何处理为数据表分配数据行时的空值

go - 拥有一个可模拟的 Golang 网络应用程序/api 结构——(依赖注入(inject))

go - 简单的负载均衡器无法正常工作

go - 使用 reflect 遍历 go struct 字段与 case map[string]interface{} 不匹配

loops - 在嵌套 for 循环中使用并发? (蛮力)

PHP PDO : Why does Inserting NULL yields to 0

go - panic : runtime error: invalid memory address or nil pointer dereference [signal 0xc0000005 code=0x0 addr=0x8 pc=0x48be5c] goroutine 1 [running]: