runtime error: invalid memory address or nil pointer dereference (golang-gorm) for POST Request
runtime error: invalid memory address or nil pointer dereference (golang-gorm) for POST Request
//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"
您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 发送数据库
Mappings.InitializeRoutes(db)
并从上下文中获取以在处理程序中使用
func Create(c *gin.Context) {
db := c.MustGet("db").(*gorm.DB)
...
}
操场上的工作代码here
//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"
您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 发送数据库
Mappings.InitializeRoutes(db)
并从上下文中获取以在处理程序中使用
func Create(c *gin.Context) {
db := c.MustGet("db").(*gorm.DB)
...
}
操场上的工作代码here