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

Go:XORKeyStream():运行时错误:无效内存地址或零指针取消引用,go,null,Go,Null,当我尝试运行以下代码时(我尝试在CFB模式下使用AES加密字符串的字节数组表示),我在sEnc.XORKeyStream(msgB,msgB)行上得到一个无效的内存地址或零指针解引用错误。文档中说XORKeyStream的源和目标可以是相同的字节数组(也尝试使用单独的目标,但没有骰子),但我无法找出导致错误的原因。我正在OSXLion上使用最新版本的Go应用程序引擎SDK 因为在这一点上,我仍然试图让代码简单地加密一些东西,我只是生成一个随机密钥,而不是费心去存储它 func generateK

当我尝试运行以下代码时(我尝试在CFB模式下使用AES加密字符串的字节数组表示),我在sEnc.XORKeyStream(msgB,msgB)行上得到一个无效的内存地址或零指针解引用错误。文档中说XORKeyStream的源和目标可以是相同的字节数组(也尝试使用单独的目标,但没有骰子),但我无法找出导致错误的原因。我正在OSXLion上使用最新版本的Go应用程序引擎SDK

因为在这一点上,我仍然试图让代码简单地加密一些东西,我只是生成一个随机密钥,而不是费心去存储它

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())

啊,我明白了!我错误地认为块大小与键大小相同!这解决了问题。