每个`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(响应)的更多相关文章

  1. OPENCV SVM介绍和自带例子

    依据机器学习算法如何学习数据可分为3类:有监督学习:从有标签的数据学习,得到模型参数,对测试数据正确分类:无监督学习:没有标签,计算机自己寻找输入数据可能的模型:强化学习(reinforcement ...

  2. DRF框架 之基础配置

    Vue框架的总结 """ 1.vue如果控制html 在html中设置挂载点.导入vue.js环境.创建Vue对象与挂载点绑定 2.vue是渐进式js框架 3.vue指令 ...

  3. Django rest_frameword 之项目流程

    后端开发软件目录规范 一.Model from django.db import models # Create your models here. # 多表的设计 # 图书 作者 出版社 作者详情表 ...

  4. DRF框架之视图类

    前后端分离的项目 >: pip3 install djangorestframework   一.视图类传递参数给序列化类 视图层:views.py 需求: (1)在视图类中实列化对象是,可以设 ...

  5. Go Revel 学习指南

    Go Revel 学习指南 CONTROLLERS(控制器) Routing(路由)http://www.cnblogs.com/hangxin1940/p/3267065.html Paramete ...

  6. ASP.NET Core 中文文档 第四章 MVC(4.1)Controllers, Actions 和 Action Results

    原文:Controllers, Actions, and Action Results 作者:Steve Smith 翻译:姚阿勇(Dr.Yao) 校对:许登洋(Seay) Action 和 acti ...

  7. 来玩Play框架02 响应

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 我上一章总结了Play框架的基本使用.这一章里,我将修改和增加响应. HTTP协议 ...

  8. 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 返回 ...

  9. 解决:jmeter查看结果树的响应数据提示超过最大值Response too large to be displayed

    问题:用jmeter做接口测试时,查看结果树的数据没有显示全,给出下面的错误提示 Response too large to be displayed. Size: 1349830 > Max: ...

随机推荐

  1. 小而美的ghost driver

    做过selenium自动化项目的同学应该都遇到过这样的问题:测试用例太多,运行速度过慢导致团队成员怨声载道. 于是便有了selenium grid和多线程运行selenium测试用例的方法.这些方法各 ...

  2. angularjs框架及其生态环境 --待续

    angular的MVVM框架结构:     1. app,   2.routes, config,   3.module,   4.Controller, $scope,controller参数,事件 ...

  3. Java Nashorn--Part 3

    jjs 的 -Scripting 选项 jjs shell 是一个不错的方法来测试一些基本的 JavaScript,或者于不太熟悉的 JavaScript包进行交互(主要是指 javax.script ...

  4. Linux创建系统用户

    #!/bin/bash users_home_front_dir="/data/users/" ssh_user=$1 user_group=$2 server_user_path ...

  5. 一:php配置注意

    display_errors string 该选项设置是否将错误信息作为输出的一部分显示到屏幕,或者对用户隐藏而不显示. 设置 "stderr" 表示发送到 stderr 而不是  ...

  6. Android开发:SharedPreferences 存储数据、获取数据

    Android开发:SharedPreferences 存储数据.获取数据 email:chentravelling@163.com 开发环境:win7 64位,Android Studio. 关于S ...

  7. ASP.NET CORE做的网站运行在docker上(不用dockerfile文件部署)

    按网上的做法用dockerfile文件是可以弄得出来的,http://www.docker.org.cn/article/119.html, 不过我想把网站文件放在外面硬盘目录,再映射进去,这样只要在 ...

  8. 【iOS XMPP】使用XMPPFramewok(四):收发消息

    转自:http://www.cnblogs.com/dyingbleed/archive/2013/05/16/3075105.html 收发消息 接收消息 通过实现 - (void)xmppStre ...

  9. vue-cli 本地数据模拟

    方法一: 使用express搭建静态服务 mock数据写在json文件中,proxyTable 里将接口代理到具体mock数据json文件上.具体方法: 创建 mock 文件夹 build/dev-s ...

  10. OpenMP基础使用

    OpenMP是CPU并行加速相关的编译处理方案,VS非常早的版本号就对其提供了支持,只是默认是关闭的.要开启这一支持.仅仅须要在项目的属性中设置就能够,详细选项为:配置属性->C/C++-> ...