gin框架学习

gin框架是什么

gin框架是一个用Go语言编写的web框架,其主要可以用于微服务开发等项目使用

goland快速安装gin

直接使用goland进行创建一个新项目即可

![[Pasted image 20241116194154.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]]

点击下面的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"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

follycat

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值