beego的模块篇 - Context上下文

本文详细解释了Beego框架中的Context对象,它封装了request和response,包括Input对象用于解析请求参数和Output对象用于处理响应。还介绍了Input对象中的各种方法,如获取协议、URI、头部信息等,以及Output对象提供的方便操作,如设置header、body和cookies等。
摘要由CSDN通过智能技术生成

上下文模块主要是针对 HTTP 请求中,request 和 response 的进一步封装,他包括用户的输入和输出,用户的输入即为 request,context 模块中提供了 Input 对象进行解析,用户的输出即为 response,context 模块中提供了 Output 对象进行输出。

1. context 对象

context 对象是对 Input 和 Output 的封装,里面封装了几个方法:

  • Redirect
  • Abort
  • WriteString
  • GetCookie
  • SetCookie

context 对象是 Filter 函数的参数对象,这样你就可以通过 filter 来修改相应的数据,或者提前结束整个的执行过程。

2. Input 对象

Input 对象是针对 request 的封装,里面通过 reqeust 实现很多方便的方法,具体如下:

名称说明
Protocol获取用户请求的协议,例如 HTTP/1.0
Uri用户请求的 RequestURI,例如 /hi?id=1001
Url请求的 URL 地址,例如 /hi
Site请求的站点地址,scheme+domain 的组合,例如 http://beego.me
Scheme请求的 scheme,例如 "http" 或者 "https"
Domain请求的域名,例如 beego.me
Host请求的域名,和 domain 一样
Method请求的方法,标准的 HTTP 请求方法,例如 GET、POST 等
Is判断是否是某一个方法,例如 Is("GET") 返回 true
IsAjax判断是否是 AJAX 请求,如果是返回 true,不是返回 false
IsSecure判断当前请求是否 HTTPS 请求,是返回 true,否返回 false
IsWebsocket判断当前请求是否 Websocket 请求,如果是返回 true,否返回 false
IsUpload判断当前请求是否有文件上传,有返回 true,否返回 false
IP返回请求用户的 IP,如果用户通过代理,一层一层剥离获取真实的 IP
Proxy返回用户代理请求的所有 IP
Refer返回请求的 refer 信息
SubDomains返回请求域名的根域名,例如请求是 blog.beego.me,那么调用该函数返回 beego.me
Port返回请求的端口,例如返回 8080
UserAgent返回请求的 UserAgent,例如 Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.57 Safari/537.36
Param在路由设置的时候可以设置参数,这个是用来获取那些参数的,例如 Param(":id"),返回12
Query该函数返回 Get 请求和 Post 请求中的所有数据,和 PHP 中 $_REQUEST 类似
Header返回相应的 header 信息,例如 Header("Accept-Language"),就返回请求头中对应的信息 zh-CN,zh;q=0.8,en;q=0.6
Cookie返回请求中的 cookie 数据,例如 Cookie("username"),就可以获取请求头中携带的 cookie 信息中 username 对应的值
Sessionsession 是用户可以初始化的信息,默认采用了 beego 的 session 模块中的 Session 对象,用来获取存储在服务器端中的数据。
Body返回请求 Body 中数据,例如 API 应用中,很多用户直接发送 json 数据包,那么通过 Query 这种函数无法获取数据,就必须通过该函数获取数据。该函数已经 beego 1.5 版本之后删除,目前可以通过 RequestBody 获取数据。
GetData用来获取 Input 中 Data 中的数据
SetData用来设置 Input 中 Data 的值,上面 GetData 和这个函数都是用来方便用户在 Filter 中传递数据到 Controller 中来执行

3. Output 对象

Output 是针对 Response 的封装,里面提供了很多方便的方法:

名称说明
Header设置输出的 header 信息,例如 Header("Server","beego")
Body设置输出的内容信息,例如 Body([]byte("astaxie"))
Cookie设置输出的 cookie 信息,例如 Cookie("sessionID","beegoSessionID")
Json把 Data 格式化为 Json,然后调用 Body 输出数据
Jsonp把 Data 格式化为 Jsonp,然后调用 Body 输出数据
Xml把 Data 格式化为 Xml,然后调用 Body 输出数据
Download把 file 路径传递进来,然后输出文件给用户
ContentType设置输出的 ContentType
SetStatus设置输出的 status
Session设置在服务器端保存的值,例如 Session("username","astaxie"),这样用户就可以在下次使用的时候读取
IsCachable根据 status 判断,是否为缓存类的状态
IsEmpty根据 status 判断,是否为输出内容为空的状态
IsOk根据 status 判断,是否为 200 的状态
IsSuccessful根据 status 判断,是否为正常的状态
IsRedirect根据 status 判断,是否为跳转类的状态
IsForbidden根据 status 判断,是否为禁用类的状态
IsNotFound根据 status 判断,是否为找不到资源类的状态
IsClientError根据 status 判断,是否为请求客户端错误的状态
IsServerError根据 status 判断,是否为服务器端错误的状态

参考文章:

https://www.fansimao.com/835088.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

流光影下

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值