go语言的成神之路-筑基篇-gin常用功能

第一节-gin参数绑定

目录

第一节-?gin参数绑定

ShouldBind简要概述

功能:

使用场景:

可能的错误:

实例代码

效果展示

第二节-gin文件上传

选择要上传的文件

选择要上传的文件。

效果展示?

代码部分

第三节-gin请求重定向

第四节-gin路由和路由组

Any用法

NoRoute

路由组


ShouldBindgin框架中的一个方法,用于将请求中的数据绑定到指定的结构体上。

ShouldBind简要概述

功能
  • 它会根据请求的Content-Type自动解析请求中的数据,并将其绑定到传入的结构体指针所指向的结构体中。
  • 对于GET请求,它会尝试从查询参数中解析数据;对于POST请求,它会根据Content-Type进行不同的解析,例如application/x-www-form-urlencodedapplication/json等。
使用场景
  • 当你需要从客户端请求中提取数据并存储到结构体中时,使用ShouldBind可以方便地将请求中的数据映射到结构体的字段上。
  • 它会自动处理数据类型的转换,将请求中的字符串数据转换为结构体字段对应的类型。
可能的错误
  • 如果请求中的数据无法正确解析或转换为结构体字段的类型,ShouldBind会返回错误。
  • 例如,如果请求中某个字段的值无法转换为结构体中相应字段的类型(如将字符串 "abc" 转换为int类型),会导致绑定失败并返回错误。

实例代码

package main

import (
	"fmt"
	"net/http"

	"github.com/gin-gonic/gin"
)

// 定义结构体
type UserInfo struct {
	UserName string `form:"username"`
	Password string `form:"password"`
}

func main() {
	r := gin.Default()
	r.GET("/user", func(c *gin.Context) {
		var u UserInfo
		err := c.ShouldBind(&u)
		if err != nil {
			c.JSON(http.StatusBadRequest, gin.H{
				"error": err.Error(),
			})
		} else {
			fmt.Printf("u:%#v
", u)
			c.JSON(http.StatusOK, gin.H{
				"username": u.UserName,
				"password": u.Password,
			})
		}
	})

	
	r.Run(":1205")
}

效果展示

第二节-gin文件上传

选择要上传的文件

// 处理 POST 请求到 /upload 路径
	r.POST("/upload", func(c *gin.Context) {
		// 从请求中获取名为 f1 的文件
		f, err := c.FormFile("f1")
		if err != nil {
			// 记录错误信息
			log.Printf("Error retrieving file: %v", err)
			// 返回错误响应
			c.JSON(http.StatusBadRequest, gin.H{
				"error": "Failed to retrieve file",
			})
			return
		}
		// 验证文件大小,假设限制文件大小为 5MB
		if f.Size > 1024*1024*5 {
			// 记录文件大小超出限制的错误信息
			log.Printf("File size too large: %v", f.Size)
			// 返回错误响应
			c.JSON(http.StatusBadRequest, gin.H{
				"error": "File size exceeds limit",
			})
			return
		}
		// 验证文件类型,假设只允许 JPEG 和 PNG
		if f.Header.Get("Content-Type") != "image/jpeg" && f.Header.Get("Content-Type") != "image/png" {
			// 记录文件类型错误信息
			log.Printf("Invalid file type: %v", f.Header.Get("Content-Type"))
			// 返回错误响应
			c.JSON(http.StatusBadRequest, gin.H{
				"error": "Invalid file type",
			})
			return
		}
		// 构建保存文件的目标路径
		dst := path.Join("./", f.Filename)
		// 保存上传的文件
		if err := c.SaveUploadedFile(f, dst); err != nil {
			// 记录保存文件时的错误信息
			log.Printf("Error saving file: %v", err)
			// 返回错误响应
			c.JSON(http.StatusInternalServerError, gin.H{
				"error": "Failed to save file",
			})
			return
		}
		// 返回成功响应
		c.JSON(http.StatusOK, gin.H{
			"status": "ok",
		})
	})

对上传的文件进行相对应的操作。

选择要上传的文件。

效果展示

代码部分

因为前端部分较为简单,在这里就不再进行展示了。

package main

import (
	"log"
	"net/http"
	"path"

	"github.com/gin-gonic/gin"
)

func main() {
	// 创建一个默认的 gin 路由
	r := gin.Default()
	// 加载 index.html 文件
	r.LoadHTMLFiles("./index.html")
	// 处理 GET 请求到 /index 路径
	r.GET("/index", func(c *gin.Context) {
		// 渲染 index.html 文件
		c.HTML(http.StatusOK, "index.html", nil)
	})

	// 处理 POST 请求到 /upload 路径
	r.POST("/upload", func(c *gin.Context) {
		// 从请求中获取名为 f1 的文件
		f, err := c.FormFile("f1")
		if err != nil {
			// 记录错误信息
			log.Printf("Error retrieving file: %v", err)
			// 返回错误响应
			c.JSON(http.StatusBadRequest, gin.H{
				"error": "Failed to retrieve file",
			})
			return
		}
		// 验证文件大小,假设限制文件大小为 5MB
		if f.Size > 1024*1024*5 {
			// 记录文件大小超出限制的错误信息
			log.Printf("File size too large: %v", f.Size)
			// 返回错误响应
			c.JSON(http.StatusBadRequest, gin.H{
				"error": "File size exceeds limit",
			})
			return
		}
		// 验证文件类型,假设只允许 JPEG 和 PNG
		if f.Header.Get("Content-Type") != "image/jpeg" && f.Header.Get("Content-Type") != "image/png" {
			// 记录文件类型错误信息
			log.Printf("Invalid file type: %v", f.Header.Get("Content-Type"))
			// 返回错误响应
			c.JSON(http.StatusBadRequest, gin.H{
				"error": "Invalid file type",
			})
			return
		}
		// 构建保存文件的目标路径
		dst := path.Join("./", f.Filename)
		// 保存上传的文件
		if err := c.SaveUploadedFile(f, dst); err != nil {
			// 记录保存文件时的错误信息
			log.Printf("Error saving file: %v", err)
			// 返回错误响应
			c.JSON(http.StatusInternalServerError, gin.H{
				"error": "Failed to save file",
			})
			return
		}
		// 返回成功响应
		c.JSON(http.StatusOK, gin.H{
			"status": "ok",
		})
	})
	// 启动服务器,监听 1205 端口
	r.Run(":1205")
}

第三节-gin请求重定向

注意此处请求的是ddd

回车之后

ddd变成了a

仔细观察后端部分的代码,不难看出,访问ddd的时候,跳转到了a,访问a的时候跳转到了b,所以会打印出b中存放的信息。也就是上述效果中展示的样子。

第四节-gin路由和路由组

Any用法

Any可以匹配任何形式的请求,这里因为没有postman所以没有对其他形式的请求进行测试,大家可以自行使用postman进行测试。

NoRoute

当没有对应的请求的时候,会进入到这一函数,如果没有进行定义就会出现404错误的页面。这里也只是对404页面进行了一下自定义操作。

路由组

路由组

路由组可以嵌套路由组

路由组可以添加中间件

路由组可以添加路由

路由组可以添加静态文件

路由组可以添加模板

路由组可以添加重定向

路由组可以添加错误处理

路由组可以添加自定义渲染器

仔细观察这三个图片的url不难看出都是voide开头的,因此我们可以将它们分成一个组来进行汇总一下。将他们的公共前缀提取出来,使得代码看起来不那么繁琐。

这样看起来更加条理清晰,用一个{}进行包括。

相关推荐
内核程序员kevin14 分钟前
Go+eBPF kprobe 禁止运行指定程序
golang·ebpf·kprobe
香精煎鱼香翅捞饭18 分钟前
java通用自研接口限流组件
java·开发语言
ChinaRainbowSea37 分钟前
Linux: Centos7 Cannot find a valid baseurl for repo: base/7/x86_64 解决方案
java·linux·运维·服务器·docker·架构
囧囧 O_o37 分钟前
Java 实现 Oracle 的 MONTHS_BETWEEN 函数
java·oracle
去看日出40 分钟前
RabbitMQ消息队列中间件安装部署教程(Windows)-2025最新版详细图文教程(附所需安装包)
java·windows·中间件·消息队列·rabbitmq
计算机-秋大田43 分钟前
基于Spring Boot的宠物健康顾问系统的设计与实现(LW+源码+讲解)
java·vue.js·spring boot·后端·课程设计
JouJz1 小时前
Java虚拟机之垃圾收集(一)
java·开发语言·jvm
源码姑娘1 小时前
基于DeepSeek的智慧医药系统(源码+部署教程)
java·人工智能·程序人生·毕业设计·springboot·健康医疗·课程设计
morris1311 小时前
【redis】布隆过滤器的Java实现
java·redis·布隆过滤器
五行星辰1 小时前
Java链接redis
java·开发语言·redis