Golang Web框架Gin入门尝鲜

简介: Gin 是使用纯 Golang 语言实现的 HTTP Web 框架。它接口简洁,性能极高,现在被广泛使用。Gin的接口设计和Martini类似,但是性能却远超Martini ,官方号称二者性能相差四十倍。

前言

Gin 是使用纯 Golang 语言实现的 HTTP Web 框架。它接口简洁,性能极高,现在被广泛使用。Gin的接口设计和Martini类似,但是性能却远超Martini ,官方号称二者性能相差四十倍。

正文

Gin 框架可以作为 Golang 技术栈的小伙伴入门后台服务的基础框架。对于新手而言,学习曲线非常友善。Gin 框架的性能也非常优秀,比如官方就给出非常高的评价,原文如下:

Gin is a HTTP web framework written in Go (Golang). It features a Martini-like API with much better performance – up to 40 times faster. If you need smashing performance, get yourself some Gin.

口说无凭,下面通过一个例子来说明Gin有多简单,十行代码就可以启动一个web后台服务。

实例代码如下:

// 最简实例packagemainimport"github.com/gin-gonic/gin"funcmain() {
r :=gin.Default()
r.GET("/", func(c*gin.Context) {
c.String(200, "Hello, World")
    })
c.Run() // 默认监听8080端口}

执行代码后,你就可以访问 http://localhost:8080/ 地址了。是不是超级简单?

亮点特性

  1. 重定向(Redirecd)

重定向就是将进入一个路由的请求跳转到另一个路由里,由另一个路由完成本次请求的最终处理。在路由重定向的过程中,我们可以在第一个路由里处理部分逻辑,甚至是修改原来请求的参数,不会影响第二个路由的处理逻辑。此时,就引出了一系列问题,原本属于get的请求,是不是可以重定向成post请求?http请求是不是可以重定向成https请求吗?感兴趣的小伙伴就课后自己寻找一下答案吧。

  1. 分组路由(Grouping Routes)

如果有一组前缀都是/api开头的路由,是不是每个路由在定义的时候都要加上/api前缀,有没有更好的方法?答案是有的。这就是我们接下来要讲的分组路由,分组路由还可以更好地实现权限控制,相同权限的路由可以放到同一个分组下。

结尾

总的来说,个人非常推荐想学习 Golang 语言的同学去尝试 Gin 框架。好了,今天关于 Gin 框架的入门介绍就这么多。大家好,我是 liuzhen007(别名 Data-Mining),欢迎大家评论留言外加“一键三连”。



作者简介:😄大家好,我是 Data-Mining(liuzhen007),是一位音视频技术爱好者,前后就职于传统广电巨头和音视频互联网公司,具有丰富的音视频直播和点播相关经验,对 WebRTC、FFmpeg 和 Electron 有非常深入的了解,😄公众号:玩转音视频。同时也是 CSDN 博客专家、华为云社区云享专家、签约作者,欢迎关注我分享更多干货!😄

目录
相关文章
|
29天前
|
前端开发
【前端web入门第四天】02 CSS三大特性+背景图
本文详细介绍了CSS的三大特性:继承性、层叠性和优先级,并深入讲解了背景图的相关属性,包括背景属性、背景图的平铺方式、位置设定、缩放、固定以及复合属性。其中,继承性指子元素自动继承父元素的文字控制属性;层叠性指相同属性后定义覆盖前定义,不同属性可叠加;优先级涉及选择器权重,包括行内样式、ID选择器等。背景图部分则通过具体示例展示了如何设置背景图像的位置、大小及固定方式等。
240 91
|
29天前
|
前端开发
【前端web入门第四天】01 复合选择器与伪类选择器
本文档详细介绍了CSS中的复合选择器与伪类选择器。复合选择器包括后代选择器、子代选择器、并集选择器和交集选择器,能够更精确地定位和样式化元素。后代选择器用于选中某元素的所有后代,子代选择器仅选中直接子元素。并集选择器可为多个标签设置相同样式,而交集选择器则选中同时满足多个条件的元素。此外,还介绍了伪类选择器,如鼠标悬停效果和超链接的不同状态。
55 32
【前端web入门第四天】01 复合选择器与伪类选择器
|
2天前
|
Web App开发 JavaScript 前端开发
使用Node.js和Express框架构建Web服务器
使用Node.js和Express框架构建Web服务器
|
29天前
|
前端开发 数据安全/隐私保护
【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
本文档详细介绍了HTML表单的多种元素及其用法,包括下拉菜单(`<select>` 和 `<option>`)、文本域(`<textarea>`)、标签解释(`<label>`)、各类按钮(`<button>`)及表单重置功能、无语义布局标签(`<div>` 和 `<span>`)以及字符实体的应用。此外,还提供了一个完整的注册信息表单案例,涵盖个人信息、教育经历和工作经历等部分,展示了如何综合运用上述元素构建实用的表单。
【前端web入门第二天】03 表单-下拉菜单 文本域 label标签 按钮 【附注册信息综合案例】
|
29天前
|
前端开发
【前端web入门第三天】02 CSS字体和文本
本文详细介绍了CSS中字体和文本的相关属性。字体部分涵盖字体大小、粗细、样式、行高、字体族及`font`复合属性,通过具体示例展示了如何设置和使用这些属性。文本部分则讲解了文本缩进、对齐方式、修饰线及文字颜色等属性,并提供了实用的代码示例。此外,还简要介绍了调试工具中的一些细节,如错误属性标识和属性生效状态的控制。
52 28
|
12天前
|
Web App开发 JavaScript 前端开发
构建高效Web应用:Node.js与Express框架的深度整合
【9月更文挑战第28天】在现代Web开发领域,Node.js和Express框架的结合已成为打造高性能、易扩展应用的黄金组合。本文将深入探讨如何利用这一技术栈优化Web应用架构,提供具体实践指导,并分析其性能提升的内在机制。通过代码示例,我们将展示从基础搭建到高级功能的实现过程,旨在为开发者提供一条清晰的学习路径,以实现技术升级和项目效率的双重提升。
26 3
|
14天前
|
前端开发 开发者 Python
从零到一:Python Web框架中的模板引擎入门与进阶
在Web开发的广阔世界里,模板引擎是连接后端逻辑与前端展示的重要桥梁。对于Python Web开发者而言,掌握模板引擎的使用是从零到一构建动态网站或应用不可或缺的一步。本文将带你从基础入门到进阶应用,深入了解Python Web框架中的模板引擎。
20 3
|
16天前
|
JSON 安全 JavaScript
Web安全-JQuery框架XSS漏洞浅析
Web安全-JQuery框架XSS漏洞浅析
96 2
|
16天前
|
开发框架 JSON 缓存
震撼发布!Python Web开发框架下的RESTful API设计全攻略,让数据交互更自由!
在数字化浪潮推动下,RESTful API成为Web开发中不可或缺的部分。本文详细介绍了在Python环境下如何设计并实现高效、可扩展的RESTful API,涵盖框架选择、资源定义、HTTP方法应用及响应格式设计等内容,并提供了基于Flask的示例代码。此外,还讨论了版本控制、文档化、安全性和性能优化等最佳实践,帮助开发者实现更流畅的数据交互体验。
37 1
|
29天前
|
前端开发 JavaScript
【前端web入门第三天】01 css定义和引入方式 四种标签选择器
本文档详细介绍了CSS的基础知识及其应用。内容涵盖了CSS的定义、CSS在HTML中的引入方式,包括内部样式表、外部样式表及行内样式表的使用场景与方法。此外,还深入解析了不同种类的选择器:标签选择器、类选择器、ID选择器以及通配符选择器的功能与应用场景,并提供了实例帮助理解。最后,通过具体的新属性示例,指导如何使用这些选择器来实现基本的盒子绘制。适合初学者系统学习CSS。
39 15