【Go开源宝藏】Web框架 GIN 专场 (含思维导图) | 持续更新

简介: 【Go开源宝藏】Web框架 GIN 专场 (含思维导图) | 持续更新

image.png

image.png

image.png

image.png

package main
import (
  "github.com/gin-gonic/gin"
  "net/http"
)
func main() {
  r := gin.Default()  // 使用Default创建路由
  r.GET("/", func(c *gin.Context) {       // 这个c就是上下文,这个路由接收GET请求
    c.String(http.StatusOK, "hello world")  // 返回状态码和数据
  })
  _ = r.Run(":8000")  //监听端口默认为8080
}

image.png

image.png

  r.POST("carts", api.CreateCart)    // POST请求,一般提交表单
  r.GET("carts/:id", api.ShowCarts)  //GET请求,一般获取数据
  r.PUT("carts", api.UpdateCart)     //PUT请求,一般修改数据
  r.DELETE("carts", api.DeleteCart)  // DELETE请求,一般删除数据

image.png

package main
import (
  "github.com/gin-gonic/gin"
  "net/http"
)
func main() {
  r := gin.Default() 
  r.GET("/user/:name/:action", func(c *gin.Context) {
    name := c.Param("name") // 使用Param可以获取路由URL里面的数据
    action := c.Param("action")
    c.String(http.StatusOK, name+" rush "+action)
  })
  _ = r.Run(":8000")
}

image.png

package main
import (
  "fmt"
  "github.com/gin-gonic/gin"
  "net/http"
)
func main() {
  r := gin.Default()
  r.POST("/form", func(c *gin.Context) {
    username := c.PostForm("username")
    password := c.PostForm("password")
    c.String(http.StatusOK, fmt.Sprintf("username:%s,password:%s", username, password))
  })
  _ = r.Run(":8000")
}

image.png

package main
import (
    "github.com/gin-gonic/gin"
)
func main() {
    r := gin.Default()
    r.POST("/upload", func(c *gin.Context) {
        file, err := c.FormFile("file")  // file是参数名称
        if err != nil {
            c.String(500, "上传图片出错")   //出错就会返回这个
        }
        c.SaveUploadedFile(file, file.Filename) // 保存文件
        c.String(http.StatusOK, file.Filename)  // 返回状态码
    })
    _ = r.Run(":8000")
}

image.png

import (
    "github.com/gin-gonic/gin"
    "net/http"
)
func helloHandler(c *gin.Context) {  // 把处理函数放在这里,可以处理一些复杂的业务
    c.JSON(http.StatusOK, gin.H {
        "message": "Hello World!",   // 通过这个 gin.H{} 进行json格式的返回
    })
}
// Router 配置路由信息
func Router() *gin.Engine {
    r := gin.Default()
    r.GET("/hello", helloHandler) // 这样这个路由就比较简洁了。
    return r
}

image.png

type Product struct {
  Name          string `form:"name" json:"name"`
  CategoryID    int    `form:"category_id" json:"category_id"`
  Title         string `form:"title" json:"title" binding:"required,min=2,max=100"`
  Info          string `form:"info" json:"info" binding:"max=1000"`
  ImgPath       string `form:"img_path" json:"img_path"`
  Price         string `form:"price" json:"price"`
  DiscountPrice string `form:"discount_price" json:"discount_price"`
  OnSale      string `form:"on_sale" json:"on_sale"`
  Num       string `form:"num" json:"num"`
}

image.png

func helloHandler(c *gin.Context) {  // 把处理函数放在这里,可以处理一些复杂的业务
    var data Product 
    if err := c.ShouldBindJSON(&data); err != nil {  
        // 进行数据的绑定,这样传过来的数据就会传入这个data当中
         // gin.H封装了生成json数据的工具
         c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) // 返回错误信息
         return
      }
    c.JSON(http.StatusOK, gin.H{"status": "200"})
}
// Router 配置路由信息
func Router() *gin.Engine {
    r := gin.Default()
    r.GET("/hello", helloHandler) // 这样这个路由就比较简洁了。
    return r
}

image.png

func helloHandler(c *gin.Context) {  // 把处理函数放在这里,可以处理一些复杂的业务
    var data Product 
    if err := c.Bind(&data); err != nil {  
        // Bind()默认解析并绑定form格式,这样传过来的数据就会传入这个data当中
         c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) // 返回错误信息
         return
      }
    c.JSON(http.StatusOK, gin.H{"status": "200"})
}

image.png

type Product struct {
  Name          string `form:"name" json:"name" uri:"name”`
  CategoryID    int    `form:"category_id" json:"category_id" uri:"category_id"`
  Title         string `form:"title" json:"title" uri:“title binding:"required,min=2,max=100"`
  Info          string `form:"info" json:"info" uri:“info binding:"max=1000"`
  ImgPath       string `form:"img_path" json:"img_path" uri:"img_path"`
  Price         string `form:"price" json:"price" uri:“price`
  DiscountPrice string `form:"discount_price" json:"discount_price" uri:"discount_price"`
  OnSale      string `form:"on_sale" json:"on_sale" uri:"on_sale"`
  Num       string `form:"num" json:"num" uri:"num"`
}

image.png

func helloHandler(c *gin.Context) {  // 把处理函数放在这里,可以处理一些复杂的业务
    var data Product 
    if err := c.ShouldBindUri(&data); err != nil {  
         c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) // 返回错误信息
         return
      }
    c.JSON(http.StatusOK, gin.H{"status": "200"})
}

image.png

type User struct {
    Phone    string   `form:"phone" binding:"required,gt=10"`  //不能为空并且大于10
    Name     string    `form:"name" binding:"required"`
    Birthday time.Time `form:"birthday" time_format:"2006-01-02"` 
    // 满足格式才能接收,减少了if-else的判断
}

image.png

type User struct {
  Phone    string   `form:"phone" binding:"required,gt=10"`  //不能为空并且大于10
  Name     string    `form:"name" binding:"NotNullAndAdmin"`  // 自定义一个验证
  Birthday time.Time `form:"birthday" time_format:"2006-01-02"`
  // 满足格式才能接收,减少了if-else的判断
}

image.png

func nameNotNullAndAdmin(v *validator.Validate, topStruct reflect.Value, currentStructOrField reflect.Value, field reflect.Value, fieldType reflect.Type, fieldKind reflect.Kind, param string) bool {
  if value, ok := field.Interface().(string); ok {
    return value != "" && !("admin" == value)// 字段不能为空,并且不等于  admin
  }
  return true
}

image.png

  if v, ok := binding.Validator.Engine().(*validator.Validate); ok {
    _ = v.RegisterValidation("NotNullAndAdmin", nameNotNullAndAdmin)  //注册定义的验证方法
  }

image.png

func main() {
  r := gin.Default()
  r.GET("/json",JsonHandler)
  _ = r.Run(":8000")
}
func JsonHandler(c *gin.Context)  {
  c.JSON(200, gin.H{"message": "HelloJson", "status": 200})
}

image.png

func main() {
  r := gin.Default()  
  r.GET("/struct", StructHandler)
  _ = r.Run(":8000")
}
func StructHandler(c *gin.Context) {
  var msg struct {
    Name    string
    Message string
    Number  int
  }
  msg.Name = "FanOne"
  msg.Message = "Golang"
  msg.Number = 10001
  c.JSON(200, msg)
}

image.png

func main() {
  r := gin.Default()  
  r.GET("/xml", XMLHandler)
  _ = r.Run(":8000")
}
func XMLHandler(c *gin.Context)  {
  c.XML(200, gin.H{"message": "HelloXml"})
}

image.png

func main() {
  r := gin.Default()  
  r.GET("/yaml", YAMLHandler)
  _ = r.Run(":8000")
}
func YAMLHandler(c *gin.Context)  {
  c.YAML(200, gin.H{"message": "HelloYaml"})
}

image.png

func main() {
  r := gin.Default()  
  r.GET("/protobuf", ProtoBufHandler)
  _ = r.Run(":8000")
}
func ProtoBufHandler(c *gin.Context)  {
  reps := []int64{int64(1), int64(2)}
  // 定义数据
  label := "label"
  // 传protobuf格式数据
  data := &protoexample.Test{
    Label: &label,
    Reps:  reps,
  }
  c.ProtoBuf(200, data)
}

image.png

func main() {
    r := gin.Default()
    r.LoadHTMLGlob("tempate/*")  // 加载你的模板文件 就是html文件嗷
    r.GET("/index", func(c *gin.Context) {
        c.HTML(http.StatusOK, "index.html", gin.H{"msg": "HelloWorld", "status": "200"})
    })
    r.Run()
}

image.png

func main() {
    r := gin.Default()    
    r.Static("/assets", "./assets") // 需要定义一个静态文件目录
    r.GET("/index", func(c *gin.Context) {
        c.HTML(http.StatusOK, "index.html", gin.H{"msg": "HelloWorld", "status": "200"})
    })
    r.Run()
}

image.png

func main() {
    r := gin.Default()
    r.GET("/index", func(c *gin.Context) {
        c.Redirect(http.StatusMovedPermanently, "http://www.baidu.com")
    })
    r.Run()
}

image.png

  "github.com/gin-contrib/sessions"
  "github.com/gin-contrib/sessions/cookie"

image.png

  store := cookie.NewStore([]byte("something-very-secret"))  // 存储
  r.Use(sessions.Sessions("mysession", store))   // 其实这也算是一个中间件

image.png

    f, _ := os.Create("gin.log")
    gin.DefaultWriter = io.MultiWriter(f)
    // gin.DefaultWriter = io.MultiWriter(f, os.Stdout)

image.png

    f, _ := os.Create("gin.log")
    gin.DefaultWriter = io.MultiWriter(f, os.Stdout)
相关文章
|
25天前
|
Cloud Native JavaScript API
一文读懂云原生 go-zero 微服务框架
一文读懂云原生 go-zero 微服务框架
|
12天前
|
消息中间件 NoSQL Go
PHP转Go系列 | ThinkPHP与Gin框架之Redis延时消息队列技术实践
【9月更文挑战第7天】在从 PHP 的 ThinkPHP 框架迁移到 Go 的 Gin 框架时,涉及 Redis 延时消息队列的技术实践主要包括:理解延时消息队列概念,其能在特定时间处理消息,适用于定时任务等场景;在 ThinkPHP 中使用 Redis 实现延时队列;在 Gin 中结合 Go 的 Redis 客户端库实现类似功能;Go 具有更高性能和简洁性,适合处理大量消息。迁移过程中需考虑业务需求及系统稳定性。
|
1月前
|
Go API 数据库
[go 面试] 分布式事务框架选择与实践
[go 面试] 分布式事务框架选择与实践
|
1月前
|
SQL 关系型数据库 MySQL
「Go开源」goose:深入学习数据库版本管理工具
「Go开源」goose:深入学习数据库版本管理工具
「Go开源」goose:深入学习数据库版本管理工具
|
25天前
|
SQL JavaScript Go
Go Web 服务框架实现详解
Go Web 服务框架实现详解
|
1月前
|
缓存 JavaScript 前端开发
为开源项目 go-gin-api 增加 WebSocket 模块
为开源项目 go-gin-api 增加 WebSocket 模块
31 2
|
25天前
|
存储 Prometheus 中间件
2020最佳人气项目之Go Web框架
2020最佳人气项目之Go Web框架
|
1月前
|
缓存 监控 中间件
构建高效的Go语言Web服务器:基于Fiber框架的性能优化实践
在追求极致性能的Web开发领域,Go语言(Golang)凭借其高效的并发处理能力、垃圾回收机制及简洁的语法赢得了广泛的青睐。本文不同于传统的性能优化教程,将深入剖析如何在Go语言环境下,利用Fiber这一高性能Web框架,通过精细化配置、并发策略调整及代码层面的微优化,构建出既快速又稳定的Web服务器。通过实际案例与性能测试数据对比,揭示一系列非直觉但极为有效的优化技巧,助力开发者在快节奏的互联网环境中抢占先机。
|
1月前
|
安全 Ubuntu 测试技术
庆祝 Go 开源发布十四周年!
庆祝 Go 开源发布十四周年!
|
1月前
|
API Go 数据安全/隐私保护
go-zero微服务框架的静态文件服务
【8月更文挑战第7天】`go-zero` 微服务框架支持多种静态文件服务实现方式。常用方法是利用 `Go` 标准库 `http.FileServer`。通过设置静态文件根目录并使用 `http.StripPrefix` 去除路径前缀,能确保 `/static/` 开头的请求正确返回文件。此外,结合 `go-zero` 的路由机制可更灵活地控制静态文件服务,例如仅在特定 API 路径 `/api/static` 下提供服务,从而实现精细化访问控制。