GoWeb开发_Iris框架讲解(三):路由功能处理方式

Stella981
• 阅读 391

Context概念

Context是iris框架中的一个路由上下文对象,在iris框架中的源码路径定义为:{$goPath}\github.com\kataras\iris\context\context.go。以下是Context的声明和定义:

package contexttype Context interface {    BeginRequest(http.ResponseWriter, *http.Request) EndRequest() ResponseWriter() ResponseWriter ResetResponseWriter(ResponseWriter) Request() *http.Request SetCurrentRouteName(currentRouteName string) GetCurrentRoute() RouteReadOnly Do(Handlers) AddHandler(...Handler) SetHandlers(Handlers) Handlers() Handlers HandlerIndex(n int) (currentIndex int) Proceed(Handler) bool HandlerName() string Next() NextOr(handlers ...Handler) bool NextOrNotFound() bool NextHandler() Handler Skip() StopExecution() IsStopped() bool Params() *RequestParams Values() *memstore.Store Translate(format string, args ...interface{}) string Method() string Path() string RequestPath(escape bool) string Host() string Subdomain() (subdomain string) IsWWW() bool RemoteAddr() string GetHeader(name string) string IsAjax() bool IsMobile() bool Header(name string, value string) ContentType(cType string) GetContentType() string GetContentLength() int64 StatusCode(statusCode int) GetStatusCode() int Redirect(urlToRedirect string, statusHeader ...int) URLParamExists(name string) bool URLParamDefault(name string, def string) string URLParam(name string) string URLParamTrim(name string) string URLParamEscape(name string) string View(filename string, optionalViewModel ...interface{}) error Text(text string) (int, error) HTML(htmlContents string) (int, error) JSON(v interface{}, options ...JSON) (int, error) JSONP(v interface{}, options ...JSONP) (int, error) XML(v interface{}, options ...XML) (int, error) Markdown(markdownB []byte, options ...Markdown) (int, error) ......

在该Context的接口定义中,我们可以发现,包含很多处理请求及数据返回的操作。在iris框架内,提供给开发者一个ContextPool,即存储上下文变量Context的管理池,该变量池中有多个context实例,可以进行复用。每次有新请求,就会获取一个新的context变量实例,来进行请求的路由处理。我们在实际的案例学习中,会向大家展示关于Context的相关用法。学习者bu

正则表达式路由

Iris框架在进行处理http请求时,支持请求url中包含正则表达式。 正则表达式的具体规则为:

  • 1、使用{}对增则表达式进行包裹,url中出现类似{}样式的格式,即识别为正则表达式

  • 2、支持自定义增则表达式的变量的命名,变量名用字母表示。比如:{name}

  • 3、支持对自定义正则表达式变量的数据类型限制,变量名和对应的数据类型之间用“:”分隔开。比如:{name:string}表示增则表达式为name,类型限定为string类型

  • 4、通过context.Params()的Get()和GetXxx()系列方法来获取对应的请求url中的增则表达式的变量

  • 5、增则表达式支持变量的数据类型包括:string、int、uint、bool等

如下是正则表达式的请求示例:

app.Get("/api/users/{isLogin:bool}", func(context context.Context) {​ isLogin, err := context.Params().GetBool("isLogin") if err != nil {  context.StatusCode(iris.StatusNonAuthoritativeInfo)  return } if isLogin {  context.WriteString(" 已登录 ") } else {  context.WriteString(" 未登录 ") }})

中间件处理请求路由

当我们在iris框架中说起中间件的相关内容时,我们所讨论和学习的是在HTTP请求

点赞
收藏
评论区
推荐文章
技术小男生 技术小男生
2个月前
linux环境jdk环境变量配置
1:编辑系统配置文件vi /etc/profile2:按字母键i进入编辑模式,在最底部添加内容: JAVAHOME/opt/jdk1.8.0152 CLASSPATH.:$JAVAHOME/lib/dt.jar:$JAVAHOME/lib/tools.jar PATH$JAVAHOME/bin:$PATH3:生效配置
刚刚好 刚刚好
2个月前
css问题
1、 在IOS中图片不显示(给图片加了圆角或者img没有父级) <div<img src""/</div div {width: 20px; height: 20px; borderradius: 20px; overflow: h
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录 问题 用navicat导入数据时,报错: 原因这是因为当前的MySQL不支持datetime为0的情况。 解决修改sql\mode: sql\mode:SQL Mode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。 全局s
小森森 小森森
2个月前
校园表白墙微信小程序V1.0 SayLove -基于微信云开发-一键快速搭建,开箱即用
后续会继续更新,敬请期待2.0全新版本 欢迎添加左边的微信一起探讨!项目地址:](https://www.aliyun.com/activity/daily/bestoffer?userCodesskuuw5n) \2. Bug修复更新日历 2. 情侣脸功能大家不要使用了,现在阿里云的接口已经要收费了(土豪请随意), \ \ 和 注意
晴空闲云 晴空闲云
2个月前
css中box-sizing解放盒子实际宽高计算
我们知道传统的盒子模型,如果增加内边距padding和边框border,那么会撑大整个盒子,造成盒子的宽度不好计算,在实务中特别不方便。boxsizing可以设置盒模型的方式,可以很好的设置固定宽高的盒模型。 盒子宽高计算假如我们设置如下盒子:宽度和高度均为200px,那么这会这个盒子实际的宽高就都是200px。但是当我们设置这个盒子的边框和内间距的时候,那
艾木酱 艾木酱
1个月前
快速入门|使用MemFire Cloud构建React Native应用程序
> MemFire Cloud是一款提供云数据库,用户可以创建云数据库,并对数据库进行管理,还可以对数据库进行备份操作。它还提供后端即服务,用户可以在1分钟内新建一个应用,使用自动生成的API和SDK,访问云数据库、对象存储、用户认证与授权等功能,可专
Stella981 Stella981
1年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置 1、virsh edit centos7 找到“memory”和“vcpu”标签,将 <name>centos7</name> <uuid>2220a6d1-a36a-4fbb-8523-e078b3dfe795</uuid>
Wesley13 Wesley13
1年前
MySQL查询按照指定规则排序
1.按照指定(单个)字段排序 select * from table_name order id desc; 2.按照指定(多个)字段排序 select * from table_name order id desc,status desc; 3.按照指定字段和规则排序 selec
Wesley13 Wesley13
1年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
#### 背景描述 # Time: 2019-01-24T00:08:14.705724+08:00 # User@Host: **[**] @ [**] Id: ** # Schema: sentrymeta Last_errno: 0 Killed: 0 # Query_time: 0.315758 Lock_
helloworld_28799839 helloworld_28799839
2个月前
常用知识整理
# Javascript ## 判断对象是否为空 ```js Object.keys(myObject).length === 0 ``` ## 经常使用的三元运算 > 我们经常遇到处理表格列状态字段如 `status` 的时候可以用到 ``` vue
helloworld_34035044 helloworld_34035044
4个月前
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。 uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid() 或 uuid(sep)参数说明:sep 布尔值,生成的uuid中是否包含分隔符'',缺省为