gin框架是什么
gin框架是一个用Go语言编写的web框架,其主要可以用于微服务开发等项目使用
goland快速安装gin
直接使用goland进行创建一个新项目即可
![![[Pasted image 20241116194154.png]]](https://i-blog.csdnimg.cn/direct/653b50d468d64e4a94529900498d3f53.png)
然后编写如下代码并运行(爆红忽略即可),
package main
import (
"github.com/gin-gonic/gin"
)
func main() {
// 创建一个默认的路由引擎
r := gin.Default()
// GET:请求方式;/hello:请求的路径
// 当客户端以GET方法请求/hello路径时,会执行后面的匿名函数
r.GET("/hello", func(c *gin.Context) {
// c.JSON:返回JSON格式的数据 gin.H 是map[string]interface{}的缩写
c.JSON(200, gin.H{
"message": "Hello",
})
})
// 启动HTTP服务,默认在0.0.0.0:8080启动服务
r.Run()
}
运行后可以发现报错
![![[Pasted image 20241116194559.png]]](https://i-blog.csdnimg.cn/direct/d8dc3a6cc29f4066afc0fd08ccf9966a.png)
点击下面的go get即可进行下载
下载完成会显示编译成功即可运行代码
gin简单学习
创建服务
使用gin.Default()方法进行创建一个服务。
其不仅创建了一个Gin引擎,还自动注册了一些默认的中间件。
并且这个函数返回的是一个 *gin.Engine类型对象,这个对象是Gin的核心,用来处理HTTP请求和路由。
而除了gin.Default方法之外,还有一个gin.New()方法也可以进行创建服务,这个函数创建出的引擎是没有添加任何默认中间件的引擎实例,所有操作都可以自己进行,更加灵活。
package main
import "github.com/gin-gonic/gin"
func main() {
//创建一个服务
ginServer := gin.Default()
}
创建请求内容
使用ginServer.GET,或者ginServer.POST进行创建GET请求或者POST请求的路由。
这俩个方法都接收俩个参数,第一个为路由路径,第二个为路由处理函数,当访问这个路由时就会触发后面的路由处理函数。
import (
"github.com/gin-gonic/gin"
)
func main() {
//创建一个服务
ginServer := gin.Default()
//创建一个get请求
ginServer.GET("/hello", func(context *gin.Context) {
context.JSON(200, gin.H{
"msg": "hello"})
})
运行服务
使用的是.Run方法,Run方法启动一个HTTP服务器,开始监听并传入的请求,其接收参数为指定监听的端口
package main
import (
"github.com/gin-gonic/gin"
)
func main() {
//创建一个服务
ginServer := gin.Default()
//创建一个get请求
ginServer.GET("/hello", func(context *gin.Context) {
context.JSON(200, gin.H{
"msg": "hello"})
})
//服务器端口,以及运行服务
ginServer.Run(":8081")
}
运行后访问127.0.0.1:8081/hello即可看到hello数据被输出
RESTful API实现
使用不同的请求访问页面时,可以通过定义不同的请求方法来实现不同的功能。
并且,在gin框架中,还有一个可以匹配所有请求方法的Any方法。
package main
import (
"github.com/gin-gonic/gin"
)
func main() {
//创建一个服务
ginServer := gin.Default()
//创建一个get请求
ginServer.GET("/hello", func(context *gin.Context) {
context.JSON(200, gin.H{
"msg": "hello"})
})
ginServer.POST("/user", func(context *gin.Context) {
context.JSON(200,gin.H{
"msg":"POST"})
})
ginServer.PUT("/user", func(context *gin.Context) {
context.JSON(200,gin.H{
"msg":"PUT"})
})
//服务器端口,以及运行服务
ginServer.Run(":8082")
}
可以使用burpsuit进行测试实现。
响应加载前端页面
使用静态文件
静态文件一般使用Static()方法进行设置,Static方法将某一个目录下的静态资源(HTML,CSS,JS等)映射到指定目录中。
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Hello Go WEB</title>
</head>
<body>
<h1>WEB</h1>
</body>
</html>
package main
import (
"github.com/gin-gonic/gin"
)
func main() {
// 创建Gin路由
r := gin.Default()
// 设置静态文件路径
r.Static("/assets", "./public")
// 启动服务器
r.Run(":8080"

2976

被折叠的 条评论
为什么被折叠?



