Gin第六天---响应以及渲染

简介: Gin第六天---响应以及渲染

Gin第六天


1.数据响应


我们后端可以实现针对不同路由对应不同数据格式的响应,常用的是json格式,当然还有许多我们可以返回的数据格式,例如结构体、XML……


package main
import(
   "github.com/gin-gonic/gin"
   "github.com/gin-gonic/gin/testdata/protoexample"
)
func main(){
   r:=gin.Default()
   // JSON格式
   r.GET("/JSON", func(c *gin.Context) {
      c.JSON(200,gin.H{"message":"someJSON","status":200})
   })
   // 结构体格式
   r.GET("/Struct", func(c *gin.Context) {
      var msg struct{
         Name string
         Message string
         Number int
      }
      msg.Name="test"
      msg.Message="message"
      msg.Number=123
      c.JSON(200,msg)
   })
   // XML
   r.GET("/XML", func(c *gin.Context) {
      c.XML(200,gin.H{"message":"abc"})
   })
   // YAML
   r.GET("/YAML", func(c *gin.Context) {
      c.YAML(200,gin.H{"name":"test"})
   })
   // protobuf
   r.GET("/Protobuf", func(c *gin.Context) {
      resp:=[]int64{int64(10),int64(2)}
      label:="label"
      data:=&protoexample.Test{
         Label: &label,
         Reps: resp,
      }
      c.ProtoBuf(200,data)
   })
   r.Run(":8888")
}
复制代码


Gin中已经将常用的数据格式类型封装好了,只需要按要求将想要返回的数据格式内容写好


2. 模板渲染


这个是几乎所有web框架离不开的一个功能,也是现在很少用到的功能。为什么这么说呢,我学习了很多种web开发的框架,几乎都涉及到了html的模板渲染(模版引擎),像python里面的jinja2、springboot中的thymeleaf以及gin的LoadHTMLFiles()。但是实际开发中大多选择前后端分离,很少在用模板渲染。所以这里只是简单示范


package main
import (
   "github.com/gin-gonic/gin"
   "net/http"
)
func main(){
   r:=gin.Default()
   r.LoadHTMLGlob("static/*")
   r.GET("/index", func(c *gin.Context) {
      c.HTML(http.StatusOK,"index.html",gin.H{"title":"我是测试","ce":"123456"})
   })
   r.Run()
}
复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>{{.title}}</title>
</head>
<body>
asdfjdsjklfsdlkfj{{.ce}}
</body>
</html>
复制代码


image.png


{{}}中就可以将路由参数作为变量传入前端页面进行渲染


3.重定向


重定向应该也是web开发中比较常用到的一个功能,前端经常可以写a标签点击跳转,后端如果想要将访问的路由修改到新的路由,也需要使用重定向。假如我们想将自己的web应用首页设置为百度,就可以像下面这样重定向到百度首页


package main
import (
   "github.com/gin-gonic/gin"
   "net/http"
)
func main(){
   r:=gin.Default()
   r.GET("/index", func(c *gin.Context) {
      c.Redirect(http.StatusMovedPermanently,"https://www.baidu.com")
   })
   r.Run()
}
复制代码


image.png


返回的是301,也就是永久重定向。这里稍微提一下,响应码302对应临时重定向,二者的区别在于永久重定向代表浏览器缓存了这个重定向的关联,下次请求相同路由的时候会直接发送重定向后的路由请求。这也就是为什么很多时候明明修改了重定向的路由,但是浏览器打开显示的还是之前的重定向页面。解决这个问题很简单,可以更换一种浏览器打开,或者清除浏览器缓存。


4. 同步与异步


众所周知,Go受欢迎一个主要原因就是与生俱来的并发优势,在很多时候go对于异步处理会比其他语言简单很多。对于I/O密集型的任务,使用多线程可以大大提高CPU使用率。在go语言中,我们只需要一个go关键字,就可以将函数变为异步执行,但是注意在使用新的goroutine时我们不应该使用原始的上下文,而是应该使用它的副本。同时要注意多线程之间的并发安全问题。


package main
import (
   "github.com/gin-gonic/gin"
   "log"
   "time"
)
func main(){
   r:=gin.Default()
   r.GET("/async", func(c *gin.Context) {
      copyContext:=c.Copy()
      go func(){
         time.Sleep(3*time.Second)
         log.Println("异步执行:"+copyContext.Request.URL.Path)
      }()
   })
   r.GET("/sync", func(c *gin.Context) {
      time.Sleep(3*time.Second)
      log.Println("同步执行:"+c.Request.URL.Path)
   })
   r.Run()
}
复制代码

image.png

这样就对比了同步和异步执行的响应时间,可以看到差距还是比较明显的。


结尾


最近除了Gin,也在看python的fastapi,同样是异步支持框架,感觉写法上和flask很相似,所以学习成本不会太高,主要就是异步编码时async/await的使用,而且目前貌似fastapi社区中关于异步支持的插件并不是特别多,而且官方文档有的地方中文版都没有翻译完,很多时候看原版文档有些词不翻译还是不好理解。最后慢慢也要把Vue2收尾,再慢慢转向Vue3,争取假期还是能学完一点东西的。

目录
相关文章
|
8月前
sd.js 2.0封装:更加简化请求传参内容(逐步废弃、逐渐日落2024.01.02)
sd.js 2.0封装:更加简化请求传参内容(逐步废弃、逐渐日落2024.01.02)
|
5月前
|
程序员 Go 网络架构
不看就落后了,Go 1.22 中更好的http router
不看就落后了,Go 1.22 中更好的http router
|
5月前
|
移动开发 JavaScript 前端开发
"解锁axios GET请求新姿势!揭秘如何将数组参数华丽变身,让你的HTTP请求在云端翩翩起舞,挑战技术极限!"
【8月更文挑战第20天】二维码在移动应用中无处不在。本文详述了在UniApp H5项目中实现二维码生成与扫描的方法。通过对比插件`uni-app-qrcode`和库`qrcode-generator`生成二维码,以及使用插件和HTML5 API进行扫描,帮助开发者挑选最佳方案。无论是即插即用的插件还是灵活的JavaScript实现,都能满足不同需求。
48 0
|
7月前
|
XML 存储 JSON
gin框架学习笔记(二) ——相关数据与文件的响应
gin框架学习笔记(二) ——相关数据与文件的响应
|
缓存 前端开发 JavaScript
React-Query:解锁你的应用程序潜力,轻松解决接口请求难题!
许多状态管理库,比如`redux`,可以很流畅的管理页面的状态,也有处理副作用的能力,但往往不能很好的处理服务端的状态。
156 1
React-Query:解锁你的应用程序潜力,轻松解决接口请求难题!
|
XML JSON Go
Gin 学习之响应处理
Gin 学习之响应处理
93 0
|
前端开发
前端学习笔记202307学习笔记第六十天-axios请求响应结果的结构1
前端学习笔记202307学习笔记第六十天-axios请求响应结果的结构1
58 0
|
JavaScript 中间件 API
Gin第七天---中间件
Gin第七天---中间件
251 13
Gin第七天---中间件
|
前端开发
【React工作记录六十三】Http常见错误
【React工作记录六十三】Http常见错误
117 0
|
前端开发 数据格式
#yyds干货盘点 【React工作记录三十七】react常见的http网络请求
#yyds干货盘点 【React工作记录三十七】react常见的http网络请求
74 0