当我尝试运行以下代码时(我尝试在 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 函数,没什么有趣的。
最佳答案
由于错误,
sEnc
为 nil
。对于 cipher.NewCFBEncrypter
, "iv 必须与 Block 的 block 长度相同。"AES block 大小是 128 位还是 16 字节?例如,
iv := make([]byte, c.BlockSize())
关于Go:XORKeyStream():运行时错误:无效的内存地址或零指针取消引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7066801/