要简单地向响应添加标头,您可以使用after
Filter.
// grails-app/conf/MyFilters.groovy
class MyFilters {
def filters = {
addHeader(uri: '/*') {
after = {
response.setHeader('X-Time', value)
}
}
}
}
Edit:
要实际计算时间,使用javax.servlet.Filter而不是 Grails 过滤器。
src/groovy/com/example/myproject/MyFilter.groovy
package com.example.myproject
import javax.servlet.*
class MyFilter implements Filter {
void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) {
def start = System.currentTimeMillis()
chain.doFilter(request, response)
def elapsed = System.currentTimeMillis() - start
response.setHeader('X-Time', elapsed as String)
}
void init(FilterConfig config) { }
void destroy() { }
}
src/templates/war/web.xml(如果 src/templates 尚未在源代码树中,请运行 grails install-templates)
<filter>
<filter-name>timer</filter-name>
<filter-class>com.example.myproject.MyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>timer</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
使用的原因javax.servlet.Filter
这样您就不必区分“之前”和“之后”操作,因此可以在整个过滤器链和 servlet 执行过程中保留开始时间。
补充说明:
对我来说,想要将服务器经过的执行时间作为响应头返回似乎很奇怪。也许你有这样做的充分理由,但在大多数情况下,我会 A)更关心总往返时间(如客户端所观察到的),或者 B)记录服务器上经过的执行时间以供我使用自己的系统管理/指标目的。