ошибка времени выполнения: недопустимый адрес памяти или разыменование нулевого указателя (golang -gorm) для запроса POST - PullRequest
0 голосов
/ 25 мая 2020
//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"`
}

поэтому, когда я отправляю запрос 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"

1 Ответ

0 голосов
/ 25 мая 2020

Ваша db переменная не установлена ​​должным образом для обработчиков

Установить db в gin.Context

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

Отправить db из основного

Mappings.InitializeRoutes(db)

И получить из контекста для использования в обработчике

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

Рабочий код на игровой площадке здесь

...