Go语言 Gin处理响应

本文介绍Gin框架处理响应数据,支持以字符串、json、xml、文件等格式响应请求。

gin.Context 上下文对象支持多种返回处理结果,下面分别介绍不同的响应方式。

1.以字符串方式响应请求

通过String函数返回字符串。

函数定义:

func (c *Context) String(code int, format string, values …interface{})

r.GET("/", func(c *gin.Context) {
	c.String(http.StatusOK, "hello world")
})

2.以json格式响应请求

开发api接口的时候常用的格式就是json,下面是返回json格式数据的例子。

// localhost:8080/user
type User struct {
	Name string `json:"name"`
	Age  int    `json:"age"`
}
r.GET("/user", func(c *gin.Context) {
	u := &User{
		Name: "lucifer",
		Age:  18,
	}
	c.JSON(http.StatusOK, u)
})

3.以xml格式响应请求

开发api接口的时候,也有使用xml格式的响应,下面是返回xml格式数据的例子。

// localhost:8080/student
type Student struct {
	Name string `xml:"name"`
	Age  int    `xml:"age"`
}
r.GET("/student", func(c *gin.Context) {
	s := &Student{
		Name: "lucifer",
		Age:  19,
	}
	c.XML(http.StatusOK, s)
})

4.以文件格式响应请求

下面介绍说明,gin框架如何直接返回一个文件,可以用来做文件下载。

// 4.1 直接返回
r.GET("/file", func(c *gin.Context) {
	c.File("./readme.txt")
})
// 4.2 返回文件,指定下载文件名
r.GET("/filename", func(c *gin.Context) {
	c.FileAttachment("./readme.txt", "change_file_name.txt")
})

5.示例

package main

import (
	"github.com/gin-gonic/gin"
	"net/http"
)

/*
Gin 处理请求参数
*/
func main() {
	// 一、实例化服务
	r := gin.Default()

	// 二、路由

	// 1.直接返回string
	// localhost:8080
	r.GET("/", func(c *gin.Context) {
		c.String(http.StatusOK, "hello world")
	})

	// 2.返回json 数据
	// localhost:8080/user
	type User struct {
		Name string `json:"name"`
		Age  int    `json:"age"`
	}
	r.GET("/user", func(c *gin.Context) {
		u := &User{
			Name: "lucifer",
			Age:  18,
		}
		c.JSON(http.StatusOK, u)
	})

	// 3.返回xml数据
	// localhost:8080/student
	type Student struct {
		Name string `xml:"name"`
		Age  int    `xml:"age"`
	}
	r.GET("/student", func(c *gin.Context) {
		s := &Student{
			Name: "lucifer",
			Age:  19,
		}
		c.XML(http.StatusOK, s)
	})
	
	// 4.返回文件
	// 4.1 直接返回
	r.GET("/file", func(c *gin.Context) {
		c.File("./readme.txt")
	})
	// 4.2 返回文件,指定下载文件名
	r.GET("/filename", func(c *gin.Context) {
		c.FileAttachment("./readme.txt", "change_file_name.txt")
	})

	// 三、启动服务
	r.Run(":8080")
}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值