封装方式一、路由写在 main函数中,数据库初始连接放在 init() 函数中。、

首先看 main.go

一个初始化函数,初始化 dbfunc init() {

db.Connect()

}

第二,路由func main() {

// Configure

router := gin.Default()

// Set html render options

htmlRender := GinHTMLRender.New()

htmlRender.Debug = gin.IsDebugging()

htmlRender.Layout = "layouts/default"

// htmlRender.TemplatesDir = "templates/" // default

// htmlRender.Ext = ".html" // default

// Tell gin to use our html render

router.HTMLRender = htmlRender.Create()

router.RedirectTrailingSlash = true

router.RedirectFixedPath = true

// Middlewares

router.Use(middlewares.Connect)

router.Use(middlewares.ErrorHandler)

// Statics

router.Static("/public", "./public")

// Routes

router.GET("/", func(c *gin.Context) {

c.Redirect(http.StatusMovedPermanently, "/articles")

})

// Articles

router.GET("/new", articles.New)

router.GET("/articles/:_id", articles.Edit)

router.GET("/articles", articles.List)

router.POST("/articles", articles.Create)

router.POST("/articles/:_id", articles.Update)

router.POST("/delete/articles/:_id", articles.Delete)

// Start listening

port := Port

if len(os.Getenv("PORT")) > 0 {

port = os.Getenv("PORT")

}

router.Run(":" + port)

}

封装方式二、路由和 db单独封装到一个函数中,以传参的形式将路由传给另一个函数。

func SetUpServer() {

r := gin.Default()

// secret 相当于签名

store, _ := sessions.NewRedisStore(10, "tcp", CONFIG.Redis.Host, CONFIG.Redis.Password, []byte(CONFIG.Server.Secret))

r.Use(sessions.Sessions("session", store))

r.Use(gin.Recovery())

r.Use(Uniquify())

r.LoadHTMLGlob("templates/*")

r.Static("/static", "public/")

SetUpRoutes(r)

r.GET("/incr", func(c *gin.Context) {

c.JSON(200, gin.H{"count": c.MustGet("key").(string)})

})

// var port string

r.Run(":" + CONFIG.Server.Port)

}

封装三、将路由等封装到 Server struct 中。对此 Server 创建一个 new函数,路由等相关内容只包含在方法中。

type Server struct {

Ws *melody.Melody

Routes *gin.Engine

Games []*Game

}

func New() *Server {

ws := melody.New()

routes := gin.Default()

games := make([]*Game, 0)

return &Server{

Ws: ws,

Routes: routes,

Games: games,

}

}

...

...

func (srv *Server) RoutesInit() {

srv.Routes.GET("/jq.js", func(c *gin.Context) {

http.ServeFile(c.Writer, c.Request, "html/jq.js")

})

srv.Routes.GET("/goyaniv.js", func(c *gin.Context) {

http.ServeFile(c.Writer, c.Request, "html/goyaniv.js")

})

srv.Routes.GET("/game/:name", func(c *gin.Context) {

cookiekey, _ := c.Request.Cookie("goyanivkey")

cookieid, _ := c.Request.Cookie("goyanivid")

if cookieid == nil || cookiekey == nil {

cookieid := CreateCookie("goyanivkey", GenerateUnique())

cookiekey := CreateCookie("goyanivid", GenerateUnique())

http.SetCookie(c.Writer, cookieid)

http.SetCookie(c.Writer, cookiekey)

}

http.ServeFile(c.Writer, c.Request, "html/game.html")

})

srv.Routes.GET("/gamedev/:name", func(c *gin.Context) {

cookiekey, _ := c.Request.Cookie("goyanivkey")

cookieid, _ := c.Request.Cookie("goyanivid")

if cookieid == nil || cookiekey == nil {

cookieid := CreateCookie("goyanivkey", GenerateUnique())

cookiekey := CreateCookie("goyanivid", GenerateUnique())

http.SetCookie(c.Writer, cookieid)

http.SetCookie(c.Writer, cookiekey)

}

http.ServeFile(c.Writer, c.Request, "html/gamedev.html")

})

srv.Routes.GET("/game/:name/ws", func(c *gin.Context) {

srv.Ws.HandleRequest(c.Writer, c.Request)

})

srv.Routes.GET("/gamedev/:name/ws", func(c *gin.Context) {

srv.Ws.HandleRequest(c.Writer, c.Request)

})

srv.Ws.HandleMessage(func(s *melody.Session, msg []byte) {

FireMessage(srv, s, msg)

})

srv.Ws.HandleDisconnect(func(s *melody.Session) {

FireDisconnect(srv, s)

})

srv.Ws.HandleConnect(func(s *melody.Session) {

FireConnect(srv, s)

})

}

func (s *Server) Run() {

s.RoutesInit()

s.Routes.Run(":5000")

}

更多golang知识请关注PHP中文网golang教程栏目。

golang mysql封装_golang如何封装路由相关推荐

  1. golang mysql 回调_Golang操作MySQL的正确姿势

    封装原因: 查看了很多网上提供的ORM类型的数据库操作,觉得比较麻烦,需要提前配置很多的表结构体,然后才能使用,对于数据表很多的项目就配置起来就比较麻烦,所以对golang的mysql包进行了外层包装 ...

  2. golang mysql 事务_golang的嵌套事务管理-Go语言中文社区

    golang的事务管理是一件很麻烦的事,,能不能像Java那样,通过Spring管理事务,最近琢磨了一下,写了一个demo,用来管理golang的事务,使其支持golang事务的嵌套调用. 其思想很简 ...

  3. golang mysql 中间件_golang编写的数据库中间件kingshard

    偶然网上看到这个kingshard,自己对golang感兴趣就试玩了一下,可以正常跑成功. 数据库中间件是什么呢?简单的说和数据库类似,不同的是当程序里发送sql给它的时候,它会根据配置对sql进行分 ...

  4. golang mysql单元测试_golang test测试使用

    1.创建测试文件夹mysql,文件夹下的go文件的package必须与文件夹名一致(不然会识别不到) 2.创建需要测试的文件mysql.go(使用github.com/go-sql-driver/my ...

  5. golang mysql 超时_golang中mysql建立连接超时时间timeout 测试

    本文测试连接mysql的超时时间. 这里的"连接"是建立连接的意思. 连接mysql的超时时间是通过参数timeout设置的. 1.建立连接超时测试 下面例子中,设置连接超时时间为 ...

  6. golang mysql 单元测试_golang 之单元测试

    测试 测试是自动化测试的简称,即编写简单的程序来确保程序(产品代码)在测试中针对特定输入产生预期的输出.Go的测试方法看上去相对比较低级,它依赖于命令go test和一些能用go test运行的测试函 ...

  7. golang mysql单例模式_Golang设计模式——单例模式

    要点:sync.Once 的应用 高并发场景下读写锁 package singleton import "sync" var  ( p *Pet once sync.Once ) ...

  8. python mysql操作封装库_python封装mysq操作,进行数据库的增删改

    python操作mysql进行封装,封装的好处我就不提了,以下是我做项目时的一个封装,大家可以根据实际需要进行自己的一个封装 我封装的内容: 1.数据库的配置文件 2.获取数据配置文件的地址 3.连接 ...

  9. linux otl 连接mysql_Linux下用OTL操作MySql(包括自己封装的类库及示例代码下载)...

    (1)首先安装MySql数据库服务: (2)安装navicat数据库客户端: 安装步骤:傻瓜安装,选择字符集的时候自己根据情况选择gbk2312,或者utf-8(一般涉及到网络传输或者跨平台,比如和j ...

最新文章

  1. 演示:GLBP跟踪功能、权值、与不同的负载均衡方式
  2. 如何上传应用到百度应用(图解攻略)
  3. KNN-----Python程序学习(一)
  4. 从文本分类来看图卷积神经网络
  5. boost::python::def相关的测试程序
  6. ubuntu kylin 14.04编译openjdk-7u40
  7. 5行代码AC——L1-029 是不是太胖了 (5分)
  8. linux gcc 简单使用记录01
  9. cookie与session原理详解
  10. python bootstrap 视频_想用Django+ Bootstrap写一个网站, 有哪些比较系统完整的书或者视频可以参考?...
  11. js indexOf()
  12. 使用pymongo连接mongodb时报错:pymongo.errors.OperationFailure: not authorized
  13. 最简单的字符串算式计算方法
  14. 【狂神说Redis】1NoSQL概述1-2什么是NoSQL
  15. vue 下载本地静态资源(xls等)
  16. it超火图片熊猫头你最成功表情包合集
  17. extends和implement的区别
  18. 怎么解决Myeclipse导入项目中文乱码?
  19. 29、程序员的面试考题,要求用一个for循环打出乘法表。
  20. 基于32feet.net对Broadcom(Widcomm)蓝牙开发

热门文章

  1. python document_python处理document文档保留原样式
  2. io密集型和cpu密集型_一次说明白Python爬虫中多线程,多进程,异步IO编程
  3. 以太坊白皮书_以太坊发展历程
  4. linux 当前用户执行定时任务
  5. 一分钟在Linux 环境 搭建 SFTP服务器
  6. 第九篇:Spring Boot整合Spring Data JPA_入门试炼02
  7. 1450. 在既定时间做作业的学生人数
  8. Vue3---安装Element-Plus组件库
  9. angular封装富文本编辑器指令
  10. pom 导入mysql连接,maven项目中的jdbc连接步骤