使用 Golang 中的 Gorm 和 Gin 实现连接
来源:stackoverflow
时间:2024-03-21 17:54:50 386浏览 收藏
本文档描述了使用 Gorm 和 Gin 库创建 API 时遇到的错误。错误是“运行时错误:无效的内存地址或零指针”。错误的根本原因是尝试取消引用未初始化的服务器指针。本文档包含了代码片段,这些代码片段展示了如何通过在 Postgres 包中声明服务器对象并初始化数据库连接来解决此问题。此外,本文档还建议在 main.go 中调用 startapplication 函数来启动应用程序。
我正在尝试使用 go
、gorm
和 gin
创建 api。然而,使用直接 sql 查询确实有效,但它变得太麻烦了,我决定利用 gorm
,这非常棒。然而,在我实施之后,我无法再次启动该项目并不断出现错误
恐慌:运行时错误:无效的内存地址或零指针 取消引用 [信号 sigsegv:分段违规代码=0x1 addr=0xb0 电脑=0x137b606]
我已将我的代码与包粘贴到此处。如果有人能指出我的问题,我会很高兴。
postgresdoa.go
package postgres import ( "fmt" "log" "net/http" "github.com/adieolami/bookstore_users-api/domain/users" "github.com/gin-gonic/gin" "github.com/jinzhu/gorm" ) type sever struct { db *gorm.db router *gin.engine } func (server *sever) initialize(dbdriver, dbuser, dbpassword, dbport, dbhost, dbname string) { var err error if dbdriver == "mysql" { dburl := fmt.sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8&parsetime=true&loc=local", dbuser, dbpassword, dbhost, dbport, dbname) server.db, err = gorm.open(dbdriver, dburl) if err != nil { fmt.printf("cannot connect to %s database", dbdriver) log.fatal("this is the error:", err) } else { fmt.printf("we are connected to the %s database", dbdriver) } } if dbdriver == "postgres" { dburl := fmt.sprintf("host=%s port=%s user=%s dbname=%s sslmode=disable password=%s", dbhost, dbport, dbuser, dbname, dbpassword) server.db, err = gorm.open(dbdriver, dburl) if err != nil { fmt.printf("cannot connect to %s database", dbdriver) log.fatal("this is the error:", err) } else { fmt.printf("we are connected to the %s database", dbdriver) } } server.db.debug().automigrate(&users.user{}) //database migration server.router = gin.default() } func (server *sever) run(addr string) { fmt.println("listening to port 8080") log.fatal(http.listenandserve(addr, server.router)) }
userdto.go
package users import ( "strings" "github.com/adieolami/bookstore_users-api/domain/base" "github.com/adieolami/bookstore_users-api/utils/errors" "github.com/jinzhu/gorm" uuid "github.com/satori/go.uuid" ) type user struct { base.base userid uuid.uuid `gorm:"type:uuid;column:userid;not null;" json:"userid"` firstname string `gorm:"size:255;not null;unique;column:firstname" json:"firstname"` lastname string `gorm:"size:255;not null;unique;column:lastname" json:"lastname"` email string `gorm:"size:100;not null;unique;column:email" json:"email"` } func (user *user) validate() *errors.error { user.email = strings.trimspace(strings.tolower(user.email)) if user.email == "" { return errors.newbadrequesterror("invalid email address") } return nil } func (user *user) saveuser(db *gorm.db) *errors.error { var err error err = db.debug().create(&user).error if err != nil { return errors.newinteralservererror(err.error()) } return nil }
userservice.go
package services import ( "github.com/adieolami/bookstore_users-api/domain/users" "github.com/adieolami/bookstore_users-api/utils/errors" ) func (server *server) createuser(user users.user) (*users.user, *errors.error) { if err := user.validate(); err != nil { return nil, err } if err := user.saveuser(server.db); err != nil { return nil, err } return &user, nil }
usercontroller.go
package users import ( "net/http" "strconv" "github.com/adieolami/bookstore_users-api/domain/users" "github.com/adieolami/bookstore_users-api/services" "github.com/adieolami/bookstore_users-api/utils/errors" "github.com/gin-gonic/gin" ) var ( server = services.server{} ) // create user func createuser(c *gin.context) { var user users.user if err := c.shouldbindjson(&user); err != nil { // todo: hnadle json error return bad request err := errors.newbadrequesterror("invalid json body") c.json(err.status, err) // fmt.println(err.error()) return } result, saveerr := server.createuser(user) if saveerr != nil { // todo: handle user createing error c.json(saveerr.status, saveerr) return } c.json(http.statuscreated, result) }
routes.go
package app import ( "github.com/adieolami/bookstore_users-api/controllers/users" "github.com/adieolami/bookstore_users-api/database/postgres" ) var ( server = postgres.sever{} ) func initializeroutes() { server.router.post("/users", users.createuser) }
application.go
package app import ( "os" "github.com/adieolami/bookstore_users-api/seed" _ "github.com/jinzhu/gorm/dialects/mysql" //mysql database driver _ "github.com/jinzhu/gorm/dialects/postgres" //postgres database driver ) func startapplication() { server.initialize(os.getenv("db_driver"), os.getenv("db_user"), os.getenv("db_password"), os.getenv("db_port"), os.getenv("db_host"), os.getenv("db_name")) seed.load(server.db) server.run(":8088") initializeroutes() }
在我的main.go
func main() { app.StartApplication() }
解决方案
据我从你的代码中可以理解。您在 services
包中声明了以下函数,而 server
对象在 postgres
包中声明。这会导致指针 server *server
取消引用到无效地址。您必须在 posgres
包中声明此函数。
func (server *Server) CreateUser(user users.User) (*users.User, *errors.Error) { if err := user.Validate(); err != nil { return nil, err } if err := user.SaveUser(server.DB); err != nil { return nil, err } return &user, nil }
终于介绍完啦!小伙伴们,这篇关于《使用 Golang 中的 Gorm 和 Gin 实现连接》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习