golang GF框架
GF(Go Frame)是一款模块化、松耦合、轻量级、高性能的Go语言Web开发框架。支持热重启、热更新、多域名、多端口、多服务、HTTP/HTTPS、动态路由等特性 ,并提供了Web服务开发的系列核心组件,如:Router、Cookie、Session、服务注册、配置管理、模板引擎、数据校验、分页管理、数据库ORM等等等等, 并且提供了数十个实用开发模块集,如:缓存、日志、时间、命令行、二进制、文件锁、对象池、连接池、数据编码、进程管理、进程通信、TCP/UDP组件、 并发安全容器、Goroutine池等等等等等等。
开源项目地址(仓库保持实时同步): Gitee,Github。 使用中有任何问题/建议,欢迎加入技术QQ群交流:116707870。 如有优秀的框架使用案例,欢迎联系作者将地址展示到项目库中,您的牛逼将被世人所瞻仰。
安装
go get -u /johng/gf
限制
golang版本 >= 1.9.2
特点
-
轻量级、高性能,模块化、松耦合设计,丰富的开发模块;
热重启、热更新特性,并支持Web界面及命令行管理接口;
专业的技术交流群,完善的开发文档及示例代码,良好的中文化支持;
支持多种形式的服务注册特性,灵活高效的路由控制管理;
支持服务事件回调注册功能,可供选择的pprof性能分析模块;
支持配置文件及模板文件的自动检测更新机制,即修改即生效;
支持自定义日期时间格式的时间模块,类似PHP日期时间格式化;
强大的数据/表单校验模块,支持常用的40种及自定义校验规则;
强大的网络通信TCP/UDP组件,并提供TCP连接池特性,简便高效;
提供了对基本数据类型的并发安全封装,提供了常用的数据结构容器;
支持Go变量/Json/Xml/Yml/Toml任意数据格式之间的相互转换及创建;
强大的数据库ORM,支持应用层级的集群管理、读写分离、负载均衡,查询缓存、方法及链式ORM操作;
更多特点请查阅框架手册和源码;
文档
GoFrame开发文档:
使用
Hello World
package main
import (
"/johng/gf/g"
"/johng/gf/g/net/ghttp"
)
func main() {
s := ()
("/", func(r *) {
("Hello World")
})
()
}
多域名支持
package main
import (
"/johng/gf/g"
"/johng/gf/g/net/ghttp"
)
func main() {
s := ()
("localhost1,localhost2").BindHandler("/", func(r *) {
("localhostx")
})
()
}
多端口支持
package main
import (
"/johng/gf/g"
"/johng/gf/g/net/ghttp"
)
func main() {
s := ()
("/", func(r *){
("go frame!")
})
(8080, 8081, 8082)
()
}
路由控制
package main
import (
"/johng/gf/g"
"/johng/gf/g/net/ghttp"
)
func main() {
s := ()
("/order/:action/{page}.html", func(r ){
("action:%s, page:%s", ("action"), ("page"))
})
(8199)
()
}
数据库ORM
ORM创建/关闭
// 获取默认配置的单例数据库对象(配置名称为"default")
db, err := ()
// 获取配置分组名称为"user-center"的单例数据库对象
db, err := ("user-center")
// 无须显示Close,数据库引擎底层采用了链接池设计,当链接不再使用时会自动关闭
单表/联表查询
// 查询多条记录并使用Limit分页
r, err := ("user").Where(" > ?", 1).Limit(0, 10).Select()
// 查询符合条件的单条记录(第一条)
r, err := ("user u").LeftJoin("user_detail ud", "=").Fields("u.,").Where("=?", 1).One()
// 查询指定字段值
r, err := ("user u").RightJoin("user_detail ud", "=").Fields("").Where("=?", 1).Value()
// 分组及排序
r, err := ("user u").InnerJoin("user_detail ud", "=").Fields("u.,").GroupBy("city").OrderBy("register_time asc").Select()
// 不使用john的联表查询
r, err := ("user u,user_detail ud").Where("=").Fields("u.,").All()
// 不使用Fields方法指定查询字段时,默认查询为"*"
r, err := ("user").Where("=1",).One()
更新/删除
// 更新
r, err := ("user").Data({"name" : "john2"}).Where("name=?", "john").Update()
r, err := ("user").Data("name='john3'").Where("name=?", "john2").Update()
// 删除
r, err := ("user").Where("uid=?", 10).Delete()
// Data数值方法的参数形式比较灵活
r, err := ("user").Data(name="john"
).Update()
r, err := ("user").Data("name", "john").Update()
r, err := ("user").Data({"name" : "john"}).Update()
写入/保存
r, err := ("user").Data({"name": "john"}).Insert()
r, err := ("user").Data({"uid": 10000, "name": "john"}).Replace()
r, err := ("user").Data({"uid": 10001, "name": "john"}).Save()
事务操作
if tx, err := (); err == nil {
if r, err := ("user").Data({"uid":1, "name": "john"}).Save(); err == nil {
()
} else {
()
}
(r, err)
}