beego 之 context 上下文模块

针对  HTTP  请求中,request (Input)和 response (Output)的进一步封装。context 对象是对 Input 和 Output 的封装。

Input 对象

具体方法如下:

  • Protocol 获取用户请求的协议,例如 HTTP/1.0
  • Uri 用户请求的 RequestURI,例如 /hi?id=1001
  • Url 请求的 URL 地址,例如 /hi
  • Site 请求的站点地址,scheme+doamin 的组合,例如 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 OSX 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 对应的值
  • Session session 是用户可以初始化的信息,默认采⽤用了 beego 的 session 模块中的 Session 对象,用来获取存储在服务器端中的数据。
  • Body 返回请求 Body 中数据,例如 API 应用中,很多用户直接发送 json 数据包,那么通过 Query 这种函数无法获取数据,就必须通过该函数获取数据。该函数已经beego1.5版本之后删除,目前可以通过RequestBody获取数据。
  • GetData 用来获取 Input 中 Data 中的数据
  • SetData 用来设置 Input 中 Data 的值,上面 GetData 和这个函数都是用来方便用户在 Filter 中传递数据到 Controller 中来执行

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://my.oschina.net/u/3625745/blog/3071941

你可能感兴趣的:(beego 之 context 上下文模块)