【问题标题】:runtime error: invalid memory address or nil pointer dereference (golang-gorm) for POST Request运行时错误:POST 请求的无效内存地址或 nil 指针取消引用(golang-gorm)
【发布时间】:2020-05-26 02:44:13
【问题描述】:
//main.go
package main

import (
    "TestGoProject/src/Mappings"
    "TestGoProject/src/Models"
    _ "github.com/gin-gonic/gin"
    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/mysql"
    _ "net/http"
)

var db *gorm.DB

func main()  {
    initDb()
    Mappings.InitializeRoutes()

}

func initDb() {
    var err error
    db, err = gorm.Open("mysql", "root:helloworld@/testapp2?charset=utf8&parseTime=True&loc=Local")

    if err != nil {
        panic("failed to connect database")
    }
    db.AutoMigrate(&Models.BookModel{})
}
//router.go
package Mappings

import (
    "TestGoProject/src/Controllers"
    "github.com/gin-gonic/gin"
)

func InitializeRoutes()  {
    router := gin.Default()
    router.GET("/", Controllers.Index)
    router.POST("/createBook", Controllers.Create)
    _ = router.Run()
}
//BookController.go
package Controllers

import (
    "TestGoProject/src/Models"
    "github.com/gin-gonic/gin"
    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/mysql"
    "net/http"
)

var db = gorm.DB{}

func Index(c *gin.Context)  {
    c.JSON(http.StatusOK, gin.H{"status": http.StatusOK, "message": "Im here!"})
}

func Create(c *gin.Context)  {
    book := Models.BookModel{
        Title: c.PostForm("title"),
        Author: c.PostForm("author"),
    }

    db.Create(&book)
    c.JSON(http.StatusCreated, gin.H{"status": http.StatusCreated, "message": "Book created successfully!", "bookId": book.ID})
}
//bookModel.go
package Models

import "github.com/jinzhu/gorm"

type BookModel struct {
    gorm.Model
    Title string `json:"title"`
    Author string `json:"author"`
}

所以当我从 Postman 发送 POST 请求时,收到这样的错误尝试解决了很多方法,但没有奏效。任何帮助都会很棒。 TIA

2020/05/25 10:54:50 [Recovery] 2020/05/25 - 10:54:50 panic recovered:
POST /createBook HTTP/1.1
Host: localhost:8080
Accept: */*
Accept-Encoding: gzip, deflate, br
Cache-Control: no-cache
Connection: keep-alive
Content-Length: 48
Content-Type: application/json
User-Agent: PostmanRuntime/7.25.0


runtime error: invalid memory address or nil pointer dereference
/usr/local/go/src/runtime/panic.go:513 (0x102bd98)
        gopanic: reflectcall(nil, unsafe.Pointer(d.fn), deferArgs(d), uint32(d.siz), uint32(d.siz))

[GIN] 2020/05/25-10:54:50|500|2.968348ms|::1|POST "/createBook"

【问题讨论】:

  • Panics 带有堆栈跟踪。找到你使用 nil 指针的代码行。
  • 只是一个没有完整堆栈跟踪的猜测:您的 Controllers.db 全局似乎没有被初始化,它是与您初始化的 main.db 不同的变量
  • 除了你的错误: 1. 不要使用相对导入。 2.为什么_有这么多import? import ( _ "net/http" ) 没有任何意义(导入时应该没有有用的副作用)。
  • 我发现不知何故 ID 总是为 Null。我不知道为什么。

标签: go go-gorm


【解决方案1】:

您的 db 变量没有为处理程序正确设置

gin.Context 中设置db

func InitializeRoutes(db *gorm.DB) {
    router := gin.Default()
    // Provide db variable to controllers
    router.Use(func(c *gin.Context) {
        c.Set("db", db)
        c.Next()
    })
    ...
}

从 main 发送 db

Mappings.InitializeRoutes(db)

并从上下文中获取以在处理程序中使用

func Create(c *gin.Context) {
    db := c.MustGet("db").(*gorm.DB)
    ...
}

操场上的工作代码here

【讨论】:

猜你喜欢
  • 2012-07-21
  • 2020-04-17
  • 2015-02-24
  • 2022-01-05
  • 2017-02-07
  • 2014-12-30
  • 2015-07-12
  • 1970-01-01
  • 2016-12-12
相关资源
最近更新 更多