gf/README.MD

205 lines
7.7 KiB
Plaintext
Raw Normal View History

## 安装
2017-11-22 16:39:21 +08:00
```
2017-11-23 10:29:50 +08:00
go get -u gitee.com/johng/gf
2017-12-31 14:44:48 +08:00
```
2017-11-22 16:39:21 +08:00
## 使用
2017-11-23 10:23:23 +08:00
```go
import "gitee.com/johng/gf/g/xxx/xxx"
2017-11-23 10:23:23 +08:00
```
## 说明
2017-12-31 14:44:48 +08:00
2017-12-31 15:13:35 +08:00
1. [框架说明](#框架介绍)
2017-12-31 14:47:58 +08:00
- [框架介绍](#框架介绍)
- [源码结构](#源码结构)
2017-12-31 15:13:35 +08:00
1. [Web服务开发](javascript:;)
- [HTTPServer](javascript:;)
- [Web Server](javascript:;)
- [多域名支持](javascript:;)
- [MVC开发模式](javascript:;)
- [Controller](javascript:;)
- [Model](javascript:;)
- [View](javascript:;)
- [服务注册](javascript:;)
- [控制器注册](javascript:;)
- [REST控制器](javascript:;)
- [执行对象注册](javascript:;)
- [回调函数注册](javascript:;)
- [Cookie](javascript:;)
- [Session](javascript:;)
- [路由控制](javascript:;)
- [配置管理](javascript:;)
- [单例管理](javascript:;)
- [数据校验](javascript:;)
- [模板引擎](javascript:;)
- [数据库操作](javascript:;)
1. [网络服务开发](javascript:;)
- [TCPServer](javascript:;)
- [UDPServer](javascript:;)
1. [功能模块设计](javascript:;)
- [缓存模块](javascript:;)
- [日志模块](javascript:;)
- [时间模块](javascript:;)
- [命令行模块](javascript:;)
- [环境变量模块](javascript:;)
- [文件管理模块](javascript:;)
- [并发安全容器](javascript:;)
- [通用编码模块](javascript:;)
- [其他模块简介](javascript:;)
2017-12-31 14:44:48 +08:00
### 框架介绍
2017-12-31 15:13:35 +08:00
gf(Go Frame)是一款为Web服务及网络服务开发设计的轻量级的Go语言开发框架。
gf框架基于模块化设计实现了通用的HTTP/TCP/UDP Server并实现了Web服务开发的相关核心组件
包括MVC模式、Cookie、Session、模板引擎、路由控制、配置管理、数据校验、数据库操作等等
并且提供了数十个自行研发的实用模块,包括:缓存模块、日志模块、时间模块、命令行模块、环境变量模块、并发安全容器等等。
2017-12-31 14:44:48 +08:00
### 源码结构
.
├── g 【框架目录】
2017-12-28 15:21:25 +08:00
│   ├── container 【常用数据结构】
│   │   ├── gbtree B+树
│   │   ├── glist 并发安全的双向链表
│   │   ├── gmap 并发安全的哈希表
│   │   └── gset 并发安全的集合
│   │  
│   ├── database 【数据库操作】
2017-12-20 12:05:36 +08:00
│   │   └── gdb 通用关系型数据库操作封装(目前仅支持MySQL、PostgreSQL)
│   │  
│   ├── encoding 【数据编码】
│   │   ├── gbase64 BASE64
│   │   ├── gbinary 二进制操作
│   │   ├── gcompress 数据压缩
│   │   ├── gcrc32 CRC32
│   │   ├── ghash 常用哈希函数
2017-12-29 17:07:03 +08:00
│   │   ├── ghtml HTML编码
│   │   ├── gjson JSON
│   │   ├── gmd5 MD5
│   │   ├── gsha1 SHA1
│   │   └── gurl URL
│   │  
2017-12-20 12:05:36 +08:00
│   ├── frame 【开发框架】
│   │   ├── gcfg 通用配置管理
│   │   ├── gins 单例对象管理
2017-12-20 12:05:36 +08:00
│   │   └── gmvc MVC模式封装基类
│   │  
│   ├── net 【网络通信】
2017-12-31 12:16:32 +08:00
│   │   ├── ghttp 强大的HTTP客户端及服务端
2017-12-29 17:07:03 +08:00
│   │   ├── gipv4 IPv4操作
│   │   ├── gipv6 IPv6操作
│   │   ├── grouter 路由管理
│   │   ├── gscanner 端口扫描
2017-12-07 09:58:35 +08:00
│   │   ├── gsmtp SMTP邮件管理
2017-12-08 10:16:40 +08:00
│   │   ├── gtcp TCP服务端
│   │   └── gudp UDP服务端
│   │  
│   ├── os 【系统管理】
2017-12-29 17:07:03 +08:00
│   │   ├── gcache 缓存管理
│   │   ├── gcmd 命令行控制
2017-12-29 17:07:03 +08:00
│   │   ├── genv 环境变量
│   │   ├── gfile 文件管理
│   │   ├── gfilepool 文件指针池
│   │   ├── gfilespace 文件碎片管理
│   │   ├── glog 日志管理
2017-12-07 10:42:37 +08:00
│   │ ├── gmmap MMAP文件内存映射
2017-12-20 12:05:36 +08:00
│   │   ├── gtime 时间管理
│   │   └── gview 视图管理(通用的模板管理对象独立于MVC模块)
│   │  
│   └── util 【常用工具】
2017-12-31 12:16:32 +08:00
│   ├── gconv 类型转换
│   ├── grand 随机数
│   ├── gregx 正则表达式
2017-12-29 17:01:48 +08:00
│   ├── gvalid 表单校验
│   └── gutil 其他工具
│  
├── geg 【框架示例】
├── vendor 【第三方包】
└── version.go 【版本信息】
2017-12-31 15:13:35 +08:00
## 配置
1. 默认读取文件运行目录的config.json文件
1. 支持多配置文件管理,默认配置文件目录为当前运行目录;
2017-12-20 12:05:36 +08:00
1. config.json配置文件说明
2018-01-04 11:59:35 +08:00
```json
{
"viewpath" : "视图文件存放路径",
"routings" : {
"dispatch" : {
"解析匹配规则1" : "解析替换规则1",
"解析匹配规则2" : "解析替换规则2"
},
"patch" : {
"打包匹配规则1" : "打包替换规则1",
"打包匹配规则2" : "打包替换规则2"
2017-12-20 12:05:36 +08:00
}
2018-01-04 11:59:35 +08:00
},
"database" : {
"数据库分组名称" : [
{
"host" : "地址",
"port" : "端口",
"user" : "账号",
"pass" : "密码",
"name" : "数据库名称",
"type" : "数据库类型(mysql|pgsql)",
"role" : "数据库角色(master|slave)",
"charset" : "字符编码",
"priority" : "数据库优先级(负载均衡处理)"
}
]
2017-12-20 12:05:36 +08:00
}
2018-01-04 11:59:35 +08:00
}
```
2017-12-20 12:05:36 +08:00
1. config.json示例文件
2018-01-04 11:59:35 +08:00
```json
{
"viewpath" : "/home/www/templates/",
"routings" : {
2018-01-04 11:59:35 +08:00
"dispatch" : {
"\/list\/page\/(\d+)[\/\?]*" : "/list?page=$1&"
2017-12-20 12:05:36 +08:00
}
2018-01-04 11:59:35 +08:00
},
"database" : {
"default" : [
{
"host" : "127.0.0.1",
"port" : "3306",
"user" : "root",
"pass" : "123456",
"name" : "test",
"type" : "mysql",
"role" : "master",
"charset" : "utf8",
"priority" : "100"
},
{
"host" : "127.0.0.1",
"port" : "3306",
"user" : "root",
"pass" : "123456",
"name" : "test",
"type" : "mysql",
"role" : "slave",
"charset" : "utf8",
"priority" : "100"
}
],
"ucenter" : [
{
"host" : "127.0.0.1",
"port" : "3306",
"user" : "root",
"pass" : "123456",
"name" : "ucenter",
"type" : "mysql",
"role" : "master",
"charset" : "utf8",
"priority" : "100"
}
]
2017-12-20 12:05:36 +08:00
}
2018-01-04 11:59:35 +08:00
}
```