在BootStrap.init闭包中添加此动态方法是很常见的做法:
HttpServletRequest.metaClass.isXhr = {-> 'XMLHttpRequest' == delegate.getHeader('X-Requested-With') }这使您可以通过执行以下操作来测试当前请求是否为ajax调用:
if(request.xhr) { ... }最简单的解决方案是在您的todo操作中添加以下内容:
if(!request.xhr) { redirect(controller: 'auth', action: 'index') return false}您也可以使用过滤器/拦截器。我建立了一个解决方案,其中我使用自定义注释来注释所有仅ajax的操作,然后在过滤器中对此进行验证。
grails-app / conf / BootStrap.groovy的完整示例:
import javax.servlet.http.HttpServletRequestclass BootStrap { def init = { servletContext -> HttpServletRequest.metaClass.isXhr = {-> 'XMLHttpRequest' == delegate.getHeader('X-Requested-With') } } def destroy = { }}


