golang mysql封装_golang如何封装路由
封装方式一、路由写在 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如何封装路由相关推荐
- golang mysql 回调_Golang操作MySQL的正确姿势
封装原因: 查看了很多网上提供的ORM类型的数据库操作,觉得比较麻烦,需要提前配置很多的表结构体,然后才能使用,对于数据表很多的项目就配置起来就比较麻烦,所以对golang的mysql包进行了外层包装 ...
- golang mysql 事务_golang的嵌套事务管理-Go语言中文社区
golang的事务管理是一件很麻烦的事,,能不能像Java那样,通过Spring管理事务,最近琢磨了一下,写了一个demo,用来管理golang的事务,使其支持golang事务的嵌套调用. 其思想很简 ...
- golang mysql 中间件_golang编写的数据库中间件kingshard
偶然网上看到这个kingshard,自己对golang感兴趣就试玩了一下,可以正常跑成功. 数据库中间件是什么呢?简单的说和数据库类似,不同的是当程序里发送sql给它的时候,它会根据配置对sql进行分 ...
- golang mysql单元测试_golang test测试使用
1.创建测试文件夹mysql,文件夹下的go文件的package必须与文件夹名一致(不然会识别不到) 2.创建需要测试的文件mysql.go(使用github.com/go-sql-driver/my ...
- golang mysql 超时_golang中mysql建立连接超时时间timeout 测试
本文测试连接mysql的超时时间. 这里的"连接"是建立连接的意思. 连接mysql的超时时间是通过参数timeout设置的. 1.建立连接超时测试 下面例子中,设置连接超时时间为 ...
- golang mysql 单元测试_golang 之单元测试
测试 测试是自动化测试的简称,即编写简单的程序来确保程序(产品代码)在测试中针对特定输入产生预期的输出.Go的测试方法看上去相对比较低级,它依赖于命令go test和一些能用go test运行的测试函 ...
- golang mysql单例模式_Golang设计模式——单例模式
要点:sync.Once 的应用 高并发场景下读写锁 package singleton import "sync" var ( p *Pet once sync.Once ) ...
- python mysql操作封装库_python封装mysq操作,进行数据库的增删改
python操作mysql进行封装,封装的好处我就不提了,以下是我做项目时的一个封装,大家可以根据实际需要进行自己的一个封装 我封装的内容: 1.数据库的配置文件 2.获取数据配置文件的地址 3.连接 ...
- linux otl 连接mysql_Linux下用OTL操作MySql(包括自己封装的类库及示例代码下载)...
(1)首先安装MySql数据库服务: (2)安装navicat数据库客户端: 安装步骤:傻瓜安装,选择字符集的时候自己根据情况选择gbk2312,或者utf-8(一般涉及到网络传输或者跨平台,比如和j ...
最新文章
- 演示:GLBP跟踪功能、权值、与不同的负载均衡方式
- 如何上传应用到百度应用(图解攻略)
- KNN-----Python程序学习(一)
- 从文本分类来看图卷积神经网络
- boost::python::def相关的测试程序
- ubuntu kylin 14.04编译openjdk-7u40
- 5行代码AC——L1-029 是不是太胖了 (5分)
- linux gcc 简单使用记录01
- cookie与session原理详解
- python bootstrap 视频_想用Django+ Bootstrap写一个网站, 有哪些比较系统完整的书或者视频可以参考?...
- js indexOf()
- 使用pymongo连接mongodb时报错:pymongo.errors.OperationFailure: not authorized
- 最简单的字符串算式计算方法
- 【狂神说Redis】1NoSQL概述1-2什么是NoSQL
- vue 下载本地静态资源(xls等)
- it超火图片熊猫头你最成功表情包合集
- extends和implement的区别
- 怎么解决Myeclipse导入项目中文乱码?
- 29、程序员的面试考题,要求用一个for循环打出乘法表。
- 基于32feet.net对Broadcom(Widcomm)蓝牙开发
热门文章
- python document_python处理document文档保留原样式
- io密集型和cpu密集型_一次说明白Python爬虫中多线程,多进程,异步IO编程
- 以太坊白皮书_以太坊发展历程
- linux 当前用户执行定时任务
- 一分钟在Linux 环境 搭建 SFTP服务器
- 第九篇:Spring Boot整合Spring Data JPA_入门试炼02
- 1450. 在既定时间做作业的学生人数
- Vue3---安装Element-Plus组件库
- angular封装富文本编辑器指令
- pom 导入mysql连接,maven项目中的jdbc连接步骤