Go:XORKeyStream():运行时错误:无效内存地址或零指针取消引用
当我尝试运行以下代码时(我尝试在CFB模式下使用AES加密字符串的字节数组表示),我在sEnc.XORKeyStream(msgB,msgB)行上得到一个无效的内存地址或零指针解引用错误。文档中说XORKeyStream的源和目标可以是相同的字节数组(也尝试使用单独的目标,但没有骰子),但我无法找出导致错误的原因。我正在OSXLion上使用最新版本的Go应用程序引擎SDK 因为在这一点上,我仍然试图让代码简单地加密一些东西,我只是生成一个随机密钥,而不是费心去存储它Go:XORKeyStream():运行时错误:无效内存地址或零指针取消引用,go,null,Go,Null,当我尝试运行以下代码时(我尝试在CFB模式下使用AES加密字符串的字节数组表示),我在sEnc.XORKeyStream(msgB,msgB)行上得到一个无效的内存地址或零指针解引用错误。文档中说XORKeyStream的源和目标可以是相同的字节数组(也尝试使用单独的目标,但没有骰子),但我无法找出导致错误的原因。我正在OSXLion上使用最新版本的Go应用程序引擎SDK 因为在这一点上,我仍然试图让代码简单地加密一些东西,我只是生成一个随机密钥,而不是费心去存储它 func generateK
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)
}
func generateKey(w http.ResponseWriter,r*http.Request){
键:=make([]字节,32)
n、 错误:=随机读取(键)
错误
如果(错误!=nil){
格式打印(w,错误)
返回
}
如果(n!=32){
fmt.Fprint(w,“读取的字节不足”)
返回
}
c、 错误:=aes.NewCipher(密钥)
如果(错误!=nil){
格式打印(w,错误)
}
iv:=make([]字节,32)
n、 err=随机读数(四)
错误
如果(错误!=nil){
格式打印(w,错误)
返回
}
如果(n!=32){
fmt.Fprint(w,“读取的字节不足”)
返回
}
sEnc:=cipher.newCfB加密机(c,iv)
msg:=“要加密的文本”
msgR:=strings.NewReader(msg)
msgB:=make([]字节,msgR.Len())
n、 err=msgR.Read(msgB)
如果(错误!=nil){
格式打印(w,错误)
返回
}
如果(n==0){
fmt.Fprint(w,“不读取字节”)
返回
}
格式打印(w,msgB)
格式打印(w,“
”)
sEnc.XORKeyStream(msgB,msgB)
格式打印(w,msgB)
}
错误消息:
2011/08/15:15:58 http:紧急服务:运行时错误:无效
内存地址或零指针取消引用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.sigmanic
/private/tmp/appengine/google_appengine/goroot/src/pkg/runtime/darwin/thread.c:470
server.generateKey服务器/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_内部手动过滤器
/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
信息2011-08-15:15:58310 dev_appserver.py:4248]“获取
/genkey/aes256 HTTP/1.1“500-
我已经发布到paste bin,但它只是includes/init函数,没有什么有趣的地方。
sEnc
是nil
错误的结果。例如,“iv必须与块的块长度相同。”AES块大小是128位还是16字节?比如说,
iv := make([]byte, c.BlockSize())
啊,我明白了!我错误地认为块大小与键大小相同!这解决了问题。