Grails控制器拦截后如何返回原始目的地

发布于 2024-11-04 07:32:52 字数 427 浏览 6 评论 0原文

问候! 我在控制器中有一个拦截,如下所示:

    def beforeInterceptor = {

    if( session.sessionRoastId == null ){

        session.intendedController = params.controller
        session.intendedAction = params.action

        redirect( controller: 'roastId', action: 'enterRoastId' )
        return false
    }
}

...在处理重定向业务后,继续执行原始控制器操作并查看拦截的正确方法是什么?

现在我正在将详细信息放入会话中以便稍后访问,但是有更好的方法吗?

谢谢。

Greetings!
I have an intercept in controller like so:

    def beforeInterceptor = {

    if( session.sessionRoastId == null ){

        session.intendedController = params.controller
        session.intendedAction = params.action

        redirect( controller: 'roastId', action: 'enterRoastId' )
        return false
    }
}

... after the redirect business is taken care of, what's proper way to continue on to the original controller action and view that the intercept picked up?

Right now I'm putting the details in the session to be accessed later down the road, but is there a better way?

Thanks.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

赴月观长安 2024-11-11 07:32:52

您可以将原始目标 URI 作为参数传递给“enterRoastId”操作,然后重定向到那里。

def beforeInterceptor = {
    if( session.sessionRoastId == null ){
        redirect( controller: 'roastId', action: 'enterRoastId', params: [
            action: params.action, 
            controller: params.controller
        ])
        return false
    }
}

然后在您的操作中,在 EnterRoastId 之后:

if (params.action && params.controller) {
    redirect(controller: params.controller, action: params.action)
    return false
}

如果您不想公开操作/控制器,则只需将值传递到“enterRoastId”视图,然后通过隐藏字段将它们传回。

You can pass the original target URI as a parameter to the 'enterRoastId' action, and then redirect there.

def beforeInterceptor = {
    if( session.sessionRoastId == null ){
        redirect( controller: 'roastId', action: 'enterRoastId', params: [
            action: params.action, 
            controller: params.controller
        ])
        return false
    }
}

then in your action AFTER enterRoastId:

if (params.action && params.controller) {
    redirect(controller: params.controller, action: params.action)
    return false
}

If you don't want to expose the action/controller, then just pass the values to the 'enterRoastId' view, and pass them back via a hidden field.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文