Go Revel - Results(响应)
每个`Action`必须返回一个`revel.Result`实例,用来处理响应。它遵循了简单的接口:
type Result interface {
Apply(req *Request, resp *Response)
}
`revel.Controller`提供了一些方法来生成`Results`响应:
1、`Render`, `RenderTemplate` - 渲染模板, 传递参数
2、`RenderJson`, `RenderXml` - 将一个`struct`序列化为`json`或`xml`格式
3、`RenderText` - 返回一个纯文本响应
4、`Redirect` - 重定向到另一个`action`或URL
5、`RenderFile` - 返回一个文件, 一般作为一个附件下载
6、`RenderError` - 渲染`errors/500.html`模板来返回一个500状态
7、`NotFound` - 渲染`errors/404.html`模板来返回一个404状态
8、`Todo` - 返回一个存根响应 (500)
除此之外,开发人员还可以返回自己定义的`revel.Result`
**设置状态码与返回体**
每一个内建的`Result`都有默认的状态码与返回体,如果要手动改变,只需要简单的覆盖`response`中的属性即可:
func (c App) Action() revel.Result {
c.Response.Status = http.StatusTeapot
c.Response.ContentType = "application/dishware"
return c.Render()
}
##Render(渲染器)
在一个`action`内调用(如,`Controller.Action`)。`mvc.Controller.Render`可以做如下两件事:
1、将所有参数添加至controller的`RenderArgs`,并将它们的本地标识设置为key
2、渲染模板`views/Controller/Action.html`, 并将`RenderArgs`作为一个map传递
如果不成功,比如没找到模板,它会返回一个`ErrorResult`对象。
func (c MyApp) Action() revel.Result {
myValue := calculateValue()
return c.Render(myValue)
}
上面示例将`myValue`传递至模板。
revel需要根据调用者的方法名来确定模板的路径与参数,因此`c.Render()`只能在Action中调用。
##渲染 Json / Xml
程序可以通过传递任意Go类型来调用`RenderJson`或`RenderXml`,revel将通过`json.Marshal`或`xml.Marshal`来渲染。
如果`app.conf`中的`results.pretty=true`被定义,则将使用`MarshalIndent`进行序列化,以惨生更好的缩进供人阅读。
##Redirect(重定向)
revel提供了一下两种方式来进行重定向:
1、不传递参数来重定向至一个action
return c.Redirect(Hotels.Settings)
这种方式十分有用,它提供一定程度的类型安全与独立路由(会自动的生成URL)
2、使用一个格式化字符串重定向
return c.Redirect("/hotels/%d/settings", hotelId)
这种形式必须传递参数
它会返回一个302(临时重定向)状态码
##添加自定义Result
下面的示例演示如何创建一个自定义`Result`
创建如下类型:
type Html string
func (r Html) Apply(req *Request, resp *Response) {
resp.WriteHeader(http.StatusOK, "text/html")
resp.Out.Write([]byte(r))
}
并在action中使用:
func (c *App) Action() revel.Result {
return Html("Hello World")
}
##状态码
没一个`Result`都具有默认的状态码,可以很方便的更改它:
func (c *App) CreateEntity() revel.Result {
c.Response.Status = 201
return c.Render()
}
Go Revel - Results(响应)的更多相关文章
- OPENCV SVM介绍和自带例子
依据机器学习算法如何学习数据可分为3类:有监督学习:从有标签的数据学习,得到模型参数,对测试数据正确分类:无监督学习:没有标签,计算机自己寻找输入数据可能的模型:强化学习(reinforcement ...
- DRF框架 之基础配置
Vue框架的总结 """ 1.vue如果控制html 在html中设置挂载点.导入vue.js环境.创建Vue对象与挂载点绑定 2.vue是渐进式js框架 3.vue指令 ...
- Django rest_frameword 之项目流程
后端开发软件目录规范 一.Model from django.db import models # Create your models here. # 多表的设计 # 图书 作者 出版社 作者详情表 ...
- DRF框架之视图类
前后端分离的项目 >: pip3 install djangorestframework 一.视图类传递参数给序列化类 视图层:views.py 需求: (1)在视图类中实列化对象是,可以设 ...
- Go Revel 学习指南
Go Revel 学习指南 CONTROLLERS(控制器) Routing(路由)http://www.cnblogs.com/hangxin1940/p/3267065.html Paramete ...
- ASP.NET Core 中文文档 第四章 MVC(4.1)Controllers, Actions 和 Action Results
原文:Controllers, Actions, and Action Results 作者:Steve Smith 翻译:姚阿勇(Dr.Yao) 校对:许登洋(Seay) Action 和 acti ...
- 来玩Play框架02 响应
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 我上一章总结了Play框架的基本使用.这一章里,我将修改和增加响应. HTTP协议 ...
- web api :Action Results in Web API 2
原文:http://www.asp.net/web-api/overview/getting-started-with-aspnet-web-api/action-results Web api 返回 ...
- 解决:jmeter查看结果树的响应数据提示超过最大值Response too large to be displayed
问题:用jmeter做接口测试时,查看结果树的数据没有显示全,给出下面的错误提示 Response too large to be displayed. Size: 1349830 > Max: ...
随机推荐
- 小而美的ghost driver
做过selenium自动化项目的同学应该都遇到过这样的问题:测试用例太多,运行速度过慢导致团队成员怨声载道. 于是便有了selenium grid和多线程运行selenium测试用例的方法.这些方法各 ...
- angularjs框架及其生态环境 --待续
angular的MVVM框架结构: 1. app, 2.routes, config, 3.module, 4.Controller, $scope,controller参数,事件 ...
- Java Nashorn--Part 3
jjs 的 -Scripting 选项 jjs shell 是一个不错的方法来测试一些基本的 JavaScript,或者于不太熟悉的 JavaScript包进行交互(主要是指 javax.script ...
- Linux创建系统用户
#!/bin/bash users_home_front_dir="/data/users/" ssh_user=$1 user_group=$2 server_user_path ...
- 一:php配置注意
display_errors string 该选项设置是否将错误信息作为输出的一部分显示到屏幕,或者对用户隐藏而不显示. 设置 "stderr" 表示发送到 stderr 而不是 ...
- Android开发:SharedPreferences 存储数据、获取数据
Android开发:SharedPreferences 存储数据.获取数据 email:chentravelling@163.com 开发环境:win7 64位,Android Studio. 关于S ...
- ASP.NET CORE做的网站运行在docker上(不用dockerfile文件部署)
按网上的做法用dockerfile文件是可以弄得出来的,http://www.docker.org.cn/article/119.html, 不过我想把网站文件放在外面硬盘目录,再映射进去,这样只要在 ...
- 【iOS XMPP】使用XMPPFramewok(四):收发消息
转自:http://www.cnblogs.com/dyingbleed/archive/2013/05/16/3075105.html 收发消息 接收消息 通过实现 - (void)xmppStre ...
- vue-cli 本地数据模拟
方法一: 使用express搭建静态服务 mock数据写在json文件中,proxyTable 里将接口代理到具体mock数据json文件上.具体方法: 创建 mock 文件夹 build/dev-s ...
- OpenMP基础使用
OpenMP是CPU并行加速相关的编译处理方案,VS非常早的版本号就对其提供了支持,只是默认是关闭的.要开启这一支持.仅仅须要在项目的属性中设置就能够,详细选项为:配置属性->C/C++-> ...