书接上回,咱们曾经装置好 Iris 框架,并且构建好了 Iris 我的项目,同时配置了 fresh 主动监控我的项目的实时编译,万事俱备,只欠东风,彩虹女神蓄势待发。当初咱们来看看 Iris 的根底性能,如何编写我的项目入口文件以及配置路由零碎。
我的项目入口
事实上,Iris 遵循的是繁多入口模式,说白了就是繁多入口文件 main.go 解决我的项目所有的起源申请,如此,我的项目就防止了因为多个文件解决不同的申请而减少的安全性危险,同时也更便于我的项目的兼顾治理。在上一篇文章:急如闪电快如风, 彩虹女神跃长空,Go 语言进阶之 Go 语言高性能 Web 框架 Iris 我的项目实战 - 初始化我的项目 EP00 中,咱们曾经编写好了入口文件 main.go:
package main
import "github.com/kataras/iris/v12"
func main() {app := iris.New()
app.Use(iris.Compression)
app.Get("/", func(ctx iris.Context) {ctx.HTML("你好 <strong>%s</strong>!", "女神")
})
app.Listen(":5000")
}
这里解释一下各行代码含意,首先申明包名:
package main
随后导入 Iris 包,留神这里的版本是最新的 v12:
import "github.com/kataras/iris/v12"
接着申明入口 (main) 函数,并且初始化 Iris 构造体:
app := iris.New()
随后加载 iris.Compression 模块:
app.Use(iris.Compression)
这里 Compression 是 Iris 外部对 IO 数据进行压缩的模块,能够进步数据传输速度。
接着编写路由注册,并应用 ctx 构造体变量来打印数据:
app.Get("/", func(ctx iris.Context) {ctx.HTML("你好 <strong>%s</strong>!", "女神")
})
最初监听系统的 5000 端口:
app.Listen(":5000")
在此基础上,进行进一步的革新:
type Article struct {Title string `json:"题目"`}
这里咱们申明一个叫做 Artile(文章)的构造体,该构造体能够了解为博客零碎中文章的对象类,构造体内有一个数据类型为字符串的字段(属性)Title(题目),其隐射到 Json 后果的形容为“题目”。
接着申明函数:
func list(ctx iris.Context) {article := []Article{{"iris 第一章"},
{"iris 第二章"},
{"iris 第三章"},
}
ctx.JSON(article)
}
这里咱们申明一个叫做 list 的函数,参数为 ctx 构造体,作用是将文章的题目列表(切片),通过 Json 的模式返回。
最初将全局注册的路由,革新为子路由注册:
articleAPI := app.Party("/")
{articleAPI.Use(iris.Compression)
articleAPI.Get("/", list)
}
这里应用 Iris 构造体变量内置的 Party 办法。
实现入口文件代码:
package main
import "github.com/kataras/iris/v12"
func main() {app := iris.New()
articleAPI := app.Party("/")
{articleAPI.Use(iris.Compression)
articleAPI.Get("/", list)
}
app.Listen(":5000")
}
type Article struct {Title string `json:"题目"`}
func list(ctx iris.Context) {article := []Article{{"iris 第一章"},
{"iris 第二章"},
{"iris 第三章"},
}
ctx.JSON(article)
}
批改结束后,fresh 服务会主动帮咱们从新编译我的项目,而后拜访 http://localhost:5000
浏览器显示:
[
{题目: "iris 第一章"},
{题目: "iris 第二章"},
{题目: "iris 第三章"}
]
如此,通过入口文件返回子路由构造体数据的例子就实现了。
路由与申请形式
除了 GET 申请形式,Iris 也反对其余的一些申请形式,一共八种:
app.Get("/someGet", getting)
app.Post("/somePost", posting)
app.Put("/somePut", putting)
app.Delete("/someDelete", deleting)
app.Patch("/somePatch", patching)
app.Header("/someHead", head)
app.Options("/someOptions", options)
这里只须要将对应的函数进行绑定即可,比方:
func testpost(ctx iris.Context) {ctx.WriteString("post 申请测试")
}
随后绑定 Post 申请:
articleAPI.Post("/", testpost)
接着编写申请脚本,在我的项目以外的目录下建设 tests.go 文件:
package main
import (
"fmt"
"io/ioutil"
"net/http"
"strings"
)
func main() {resp, err := http.Post("http://localhost:5000", "application/json;charset=utf-8", strings.NewReader("name=test"))
if err != nil {fmt.Println(err)
return
}
body, err := ioutil.ReadAll(resp.Body)
fmt.Println(string(body))
}
这里通过 http 包的 Post 办法来申请 http://localhost:5000
零碎返回:
post 申请测试
没有问题。
路由传参
在 Iris 的路由体系中,咱们能够间接通过网址进行参数的传递:
app.Get("/user/{name}", func(ctx iris.Context) {name := ctx.Params().Get("name")
ctx.Writef("Hello %s", name)
})
随后编写申请脚本:
package main
import (
"fmt"
"io/ioutil"
"net/http"
)
func main() {resp, err := http.Get("http://localhost:5000/user/123")
if err != nil {fmt.Println(err)
return
}
body, err := ioutil.ReadAll(resp.Body)
fmt.Println(string(body))
}
程序返回:
Hello 123
须要留神的是,这种传参形式并不会匹配独自的 /user 门路,所以参数不能为空能力匹配到。
如果参数为空,也须要向下匹配,能够采纳这种形式:
app.Get("/user/{name}/{action:path}", func(ctx iris.Context) {name := ctx.Params().Get("name")
action := ctx.Params().Get("action")
message := name + "is" + action
ctx.WriteString(message)
})
同时也能够申明参数类型:
app.Post("/user/{name:string}/{action:path}", func(ctx iris.Context) {ctx.GetCurrentRoute().Tmpl().Src == "/user/{name:string}/{action:path}" // true
})
Iris 内置反对的参数类型:
Param Type Go Type Validation Retrieve Helper
:string string anything (single path segment) Params().Get
:uuid string uuidv4 or v1 (single path segment) Params().Get
:int int -9223372036854775808 to 9223372036854775807 (x64) or -2147483648 to 2147483647 (x32), depends on the host arch Params().GetInt
:int8 int8 -128 to 127 Params().GetInt8
:int16 int16 -32768 to 32767 Params().GetInt16
:int32 int32 -2147483648 to 2147483647 Params().GetInt32
:int64 int64 -9223372036854775808 to 9223372036854775807 Params().GetInt64
:uint uint 0 to 18446744073709551615 (x64) or 0 to 4294967295 (x32), depends on the host arch Params().GetUint
:uint8 uint8 0 to 255 Params().GetUint8
:uint16 uint16 0 to 65535 Params().GetUint16
:uint32 uint32 0 to 4294967295 Params().GetUint32
:uint64 uint64 0 to 18446744073709551615 Params().GetUint64
:bool bool "1" or "t" or "T" or "TRUE" or "true" or "True" or "0" or "f" or "F" or "FALSE" or "false" or "False" Params().GetBool
:alphabetical string lowercase or uppercase letters Params().Get
:file string lowercase or uppercase letters, numbers, underscore (_), dash (-), point (.) and no spaces or other special characters that are not valid for filenames Params().Get
:path string anything, can be separated by slashes (path segments) but should be the last part of the route path Params().Get
除此以外,Iris 也反对传统的传参形式:
func main() {app := iris.Default()
// Query string parameters are parsed using the existing underlying request object.
// The request responds to a url matching: /welcome?firstname=Jane&lastname=Doe
app.Get("/welcome", func(ctx iris.Context) {firstname := ctx.URLParamDefault("firstname", "Guest")
lastname := ctx.URLParam("lastname") // shortcut for ctx.Request().URL.Query().Get("lastname")
ctx.Writef("Hello %s %s", firstname, lastname)
})
app.Listen(":8080")
}
这里留神,如果参数为空,能够通过 ctx 构造体绑定 URLParamDefault 办法来设置默认值。
结语
通过 Iris 内置的路由、模型构造体、以及对应的构造体绑定办法,咱们曾经能够实现一般申请的响应,同时通过多种形式获取到申请的参数,下一步,将会联合 Iris 模板来将数据实时渲染至页面中,欲知后事如何,且听下回分解。