Golang Web框架还在用Gin吗,快试试全新框架Bud吧
ccwgpt 2024-09-18 12:19 38 浏览 0 评论
一、背景
在搭建Go语言的项目时,我们可能会习惯gin-gonic这样的框架。
这里来介绍一款目前简单易用,功能强大的开源框架 Bud。项目开源不到一年的时间,但是目前已经3.9K+ star,发展势头非常好。
Bud的地址:github.com/livebud/bud
Bud这个名字的由来是Buddy(伙伴)的缩写。作者希望好的框架就像安静的技术伙伴,可以提供很大的帮助。
二、使用教程
创建一个Bud项目非常简单。
环境配置
Node v14+ (官方会在v0.3版本的时候去除node js依赖)
// mac的话可以直接 brew install node
Go v1.17+
// 可以参考 Go语言安装和配置
首先执行这个命令。会远程拉一个脚本并执行 Bud 的安装
curl -sf https://raw.githubusercontent.com/livebud/bud/main/install.sh | sh
复制代码
然后使用命令 bud -h 验证安装是否成功。
创建项目
用 bud create 来创建一个项目,参数是指定的当前路径下的项目目录。
# 在 blog/ 目录下创建一个新的bud项目
bud create blog
复制代码
会生成这样的目录和文件
$ ls
go.mod node_modules/ package-lock.json package.json
复制代码
目录结构
Bud的标准目录结构如下所示:
$YOUR_APP
├─ bud
├─ controller
├─ internal
├─ public
└─ view
复制代码
bud 目录包含框架生成的代码。偶尔会需要从这个目录导入生成的包,但在大多数情况下可以忽略它的内容。 建议将此目录置于源代码控制之外。
controller 目录用于放置响应请求的代码。可用于为视图获取动态数据或提供 API。
internal 目录用于放置项目自身的代码,bud框架永远不会用到这个目录。
public 目录用于放置静态资源,比如图片和视频。
view 目录用于存储 Svelte 文件以显示给您的访问者。视图通常与控制器配对。
运行bud run可以启动项目。
# 在默认的 3000 端口启动 bud server
bud run
# 在指定端口启动 bud server
bud run --port=8080
# 以非热加载模式启动 bud server
bud run --hot=false
复制代码
三、功能与使用
###1. 网络路由
后端模块的请求处理逻辑,都是从controller开始。
当我们需要创建controller的时候,可以直接通过命令的方式创建。
# 创建一个叫作post的controller
bud new controller post
# 创建一个叫作post的controller,有index和show的function
bud new controller post index show
# 创建一个指定路由路径的controller
bud new controller post:/
复制代码
Bud框架的controller目录结构示例如下所示:
$YOUR_APP
└─ controller
├─ controller.go -> root controller
├─ posts
│ ├─ posts.go -> posts controller
│ └─ comments
│ └─ comments.go -> comments controller
└─ users
└─ users.go -> users controller
复制代码
users controller的示例如下,Bud框架对于controller的方法,都有对应的默认url路径。
package users
// Controller for /users
type Controller struct {}
// User type
type User struct {
ID int
Name string
Age int
}
// Index shows a list of users
// GET /users
func (c *Controller) Index() ([]*User, error) {}
// New user page
// GET /users/new
func (c *Controller) New() {}
// Create a new user
// POST /users
func (c *Controller) Create(name string, age int) (*User, error) {}
// Show a user
// GET /users/:id
func (c *Controller) Show(id int) (*User, error) {}
// Update a user
// PATCH /users/:id
func (c *Controller) Update(id int, name string, age int) error {}
// Delete a user
// DELETE /users/:id
func (c *Controller) Delete(id int) error {}
// Edit user page
// GET /users/:id/edit
func (c *Controller) Edit(id int) (*User, error) {}
复制代码
例如一个这样的请求
对于路径 /posts/:id/comments?order=xx&author=xx
GET /posts/10/comments?order=asc&author=Alice
复制代码
那么实际的GET请求参数是这样的:
{
"id": 10,
"order": "asc",
"author": "Alice"
}
复制代码
POST /posts/10/comments?author=Alice
{
"email": "alice@livebud.com"
}
复制代码
那么实际的POST请求参数是这样的:
{
"id": 10,
"author": "Alice",
"email": "alice@livebud.com"
}
复制代码
对于path参数和query参数有冲突的情况,例如:
POST /posts/10/comments?id=20&author=Alice
{
"id": 30,
"author": "Bob"
}
复制代码
那这时候,参数生效的优先级是这样的
1.路径值(最高优先级)
2.query参数
3.请求正文(最低优先级)
那么,最后生效的参数是这样的:
{
"id": 10,
"author": "Bob"
}
复制代码
bud框架对这一类的功能,已经有处理的逻辑了。并且对于错误参数的处理也已经有一套逻辑,不需要用户再去写这类逻辑。
2. 前端框架
bud使用的前端框架是Svelte.JS,当如1中所示创建controller和action之后,可以生成对应的svelte文件
$YOUR_APP
└─ view
├─ index.svelte -> Root index page
├─ posts
│ ├─ edit.svelte -> Edit post page
│ ├─ index.svelte -> Post index page
│ ├─ new.svelte -> New post page
│ ├─ show.svelte -> Show post page
│ └─ Post.svelte -> Post component (not rendered)
└─ users
├─ edit.svelte -> Edit user page
├─ index.svelte -> User index page
└─ show.svelte -> Show user page
复制代码
例如可以这样让controller和view交互:
controller/users/users.go
package users
type Controller struct {}
type User struct {
Name string
Age int
}
func (c *Controller) Index() []*User {
return []*User{
{"Matt", 32},
{"Mia", 31},
{"Mike", 26},
}
}
复制代码
view/users/index.svelte
<script>
export let users = []
</script>
<h1>Users</h1>
<ul>
{#each users as user}
<li>{user.name} is {user.age} years old</li>
{/each}
</ul>
复制代码
3. 扩展插件
插件以 bud- 前缀开头,看起来像任何其他 Bud 应用程序。例如,让我们创建一个插件来服务 Tailwind 的 preflight.css 文件
bud-tailwind/
├── public
│ └── preflight.css
├── go.mod
└── go.sum
复制代码
如果Bud项目的目录如下所示
$YOUR_APP
├── controller
│ └── post.go
├── public
│ └── favicon.ico
├── view
│ ├── index.svelte
│ └── show.svelte
├── go.mod
└── go.sum
复制代码
那通过执行命令 go get github.com/livebud/bud-tailwind之后,preflight.css就会安装到该bud项目中。
$YOUR_APP
├── controller
│ └── post.go
├── public
│ ├── favicon.ico
+ │ └── preflight.css
├── view
│ ├── index.svelte
│ └── show.svelte
├── go.mod
└── go.sum
复制代码
四、总结
Bud的特点:
- Bud 使用静态分析生成代码。这允许 Bud 提供更高级别的 API,这些 API 可以被编译成低级的高性能 Go 代码。
- 越来越多的捆绑代码生成器提供了特定于框架的功能。这些代码生成器与您可以自己编写的代码生成器没有什么不同。通过添加、自定义甚至丢弃这些代码生成器,让 Bud 成为您自己的。
- Bud 带来了它自己的依赖注入框架,它减少了你需要做的手动连接,并标准化了你开发模块化、可测试和可交换依赖项的方式。
但是目前Bud框架并没有自己的ORM,用户需要自行选择orm框架,通过依赖注入在控制器中使用。
另外,还有全栈框架包含的特性,如错误处理、依赖注入、数据验证及安全、文件与存储等都可以在官方文档上找到。
作者:张醒言
链接:https://juejin.cn/post/7125382825229942814
相关推荐
- 一个基于.Net Core遵循Clean Architecture原则开源架构
-
今天给大家推荐一个遵循CleanArchitecture原则开源架构。项目简介这是基于Asp.netCore6开发的,遵循CleanArchitecture原则,可以高效、快速地构建基于Ra...
- AI写代码翻车无数次,我发现只要提前做好这3步,bug立减80%
-
写十万行全是bug之后终于找到方法了开发"提示词管理助手"新版本那会儿,我差点被bug整崩溃。刚开始两周,全靠AI改代码架构,结果十万行程序漏洞百出。本来以为AI说没问题就稳了,结果...
- OneCode低代码平台的事件驱动设计:架构解析与实践
-
引言:低代码平台的事件驱动范式在现代软件开发中,事件驱动架构(EDA)已成为构建灵活、松耦合系统的核心范式。OneCode低代码平台通过创新性的注解驱动设计,将事件驱动理念深度融入平台架构,实现了业务...
- 国内大厂AI插件评测:根据UI图生成Vue前端代码
-
在IDEA中安装大厂的AI插件,打开ruoyi增强项目:yudao-ui-admin-vue31.CodeBuddy插件登录腾讯的CodeBuddy后,大模型选择deepseek-v3,输入提示语:...
- AI+低代码技术揭秘(二):核心架构
-
本文档介绍了为VTJ低代码平台提供支持的基本架构组件,包括Engine编排层、Provider服务系统、数据模型和代码生成管道。有关UI组件库和widget系统的信息,请参阅UI...
- GitDiagram用AI把代码库变成可视化架构图
-
这是一个名为gitdiagram的开源工具,可将GitHub仓库实时转换为交互式架构图,帮助开发者快速理解代码结构。核心功能一键可视化:替换GitHubURL中的"hub...
- 30天自制操作系统:第六天:代码架构整理与中断处理
-
1.拆开bootpack.c文件。根据设计模式将对应的功能封装成独立的文件。2.初始化pic:pic(可编程中断控制器):在设计上,cpu单独只能处理一个中断。而pic是将8个中断信号集合成一个中断...
- AI写代码越帮越忙?2025年研究揭露惊人真相
-
近年来,AI工具如雨后春笋般涌现,许多人开始幻想程序员的未来就是“对着AI说几句话”,就能轻松写出完美的代码。然而,2025年的一项最新研究却颠覆了这一期待,揭示了一个令人意外的结果。研究邀请了16位...
- 一键理解开源项目:两个自动生成GitHub代码架构图与说明书工具
-
一、GitDiagram可以一键生成github代码仓库的架构图如果想要可视化github开源项目:https://github.com/luler/reflex_ai_fast,也可以直接把域名替换...
- 5分钟掌握 c# 网络通讯架构及代码示例
-
以下是C#网络通讯架构的核心要点及代码示例,按协议类型分类整理:一、TCP协议(可靠连接)1.同步通信//服务器端usingSystem.Net.Sockets;usingTcpListene...
- 从复杂到优雅:用建造者和责任链重塑代码架构
-
引用设计模式是软件开发中的重要工具,它为解决常见问题提供了标准化的解决方案,提高了代码的可维护性和可扩展性,提升了开发效率,促进了团队协作,提高了软件质量,并帮助开发者更好地适应需求变化。通过学习和应...
- 低代码开发当道,我还需要学习LangChain这些框架吗?| IT杂谈
-
专注LLM深度应用,关注我不迷路前两天有位兄弟问了个问题:当然我很能理解这位朋友的担忧:期望效率最大化,时间用在刀刃上,“不要重新发明轮子”嘛。铺天盖地的AI信息轰炸与概念炒作,很容易让人浮躁与迷茫。...
- 框架设计并不是简单粗暴地写代码,而是要先弄清逻辑
-
3.框架设计3.框架设计本节我们要开发一个UI框架,底层以白鹭引擎为例。框架设计的第一步并不是直接撸代码,而是先想清楚设计思想,抽象。一个一个的UI窗口是独立的吗?不是的,...
- 大佬用 Avalonia 框架开发的 C# 代码 IDE
-
AvalonStudioAvalonStudio是一个开源的跨平台的开发编辑器(IDE),AvalonStudio的目标是成为一个功能齐全,并且可以让开发者快速使用的IDE,提高开发的生产力。A...
- 轻量级框架Lagent 仅需20行代码即可构建自己的智能代理
-
站长之家(ChinaZ.com)8月30日消息:Lagent是一个专注于基于LLM模型的代理开发的轻量级框架。它的设计旨在简化和提高这种模型下代理的开发效率。LLM模型是一种强大的工具,可以...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- mfc框架 (52)
- abb框架断路器 (48)
- beego框架 (52)
- java框架spring (58)
- grpc框架 (65)
- tornado框架 (48)
- 前端框架bootstrap (54)
- orm框架有哪些 (51)
- 知识框架图 (52)
- ppt框架 (55)
- 框架图模板 (59)
- 内联框架 (52)
- cad怎么画框架 (58)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)