尽管Grails支持良好的细粒度控制器(controller),但只对少数控制器(controller)的应用时非常有用,当管理大型应用时就会变得很困难。另一方面,过滤器能横跨一群控制器(controller),一个URI空间或一个具体的操作(action)。过滤器对插件更容易并能保证彻底的分离主要控制器(controller)逻辑,有利于所有像安全,日志等等这样的横切关注点 .
应用过滤器
为了创建一个过滤器,可在 grails-app/conf
下创建一个以规约 Filters
结尾的类。在这个类中,定义一个名为filters
的代码块,它包含了过滤器的定义 :
过滤器(Filters)类型
在过滤器的主体内,你可以定义下列过滤器(Filters)的拦截器类型之一:
before
- 操作(Action)之前执行. 返回false来指示后续的控制器(controller)和操作(action)不会被执行after
- 操作(Action)之后执行. 获取第一参数作为视图模型afterView
- 视图渲染之后执行
例如,为实现普通身份验证,可以定义如下过滤器(Filters):
变量与作用域
过滤器支持所有在 控制器(controllers) 和 标签库 中可用的属性,附加application context :
- request - HttpServletRequest对象
- response - HttpServletResponse对象
- session - HttpSession对象
- servletContext - ServletContext对象
- flash - flash对象
- params - 请求参数对象
- actionName - 被分配的action名
- controllerName - 被分配的controller名
- grailsApplication - 当前运行的Grails应用程序
- applicationContext - ApplicationContext对象
不过,过滤器只支持用于控制器(controller)和标签库方法的子集 。这些包括: