gpt4 book ai didi

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

转载 作者:IT王子 更新时间:2023-10-29 01:40:19 27 4
gpt4 key购买 nike

当我尝试运行以下代码时(我尝试在 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com