gpt4 book ai didi

grails - Grails是否允许使用过滤器进行声明式异常处理?

转载 作者:行者123 更新时间:2023-12-02 14:24:55 25 4
gpt4 key购买 nike

我想在Grails应用程序中创建一个AuthorizationFilter,它将检查请求参数并确定用户是否有权进行请求。我希望我可以从自己的AuthorizationFilter中抛出一个自定义异常,然后通过Grails声明性执行处理通过如下途径处理该异常:

"403"(controller: 'error', action: 'status403', exception:AuthException)

...但是当我在grails 2.2.4(和最新的dev快照)中尝试此操作时,我得到了
java.lang.IllegalArgumentException: Method name must not be null
at grails.plugin.cache.web.ProxyAwareMixedGrailsControllerHelper.retrieveAction(ProxyAwareMixedGrailsControllerHelper.java:41)

那么...有什么好方法可以将声明式异常处理与过滤器一起使用?

最佳答案

我猜你可以从ControllersFilters处理声明性异常。您可以改用响应来发送错误代码

class AuthorizationFilters {
def filters = {
auth(controller: 'error', invert: true) {
before = {
if(1){ //If auth fails
response.sendError(403)
//render(status: 403) //or
//redirect(controller: 'error', action: 'status403') //or
}
return false
}
}
}
}

上面的逻辑将基于问题中提供的 status403呈现ErrorController的 UrlMapping操作的响应

确保从过滤器中排除 error Controller 。

关于grails - Grails是否允许使用过滤器进行声明式异常处理?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18513316/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com