struts2:区域设置切换后如何返回用户所在的同一页面?

发布于 2024-08-30 01:24:38 字数 706 浏览 1 评论 0原文

我正在使用 struts2,并在 struts.xml 中编写了以下用于区域设置切换的代码 -

<action name="switchToEnglish">
         <interceptor-ref name="i18n"/>
         <interceptor-ref name="basicStack"/>
         <result name="input">error.jsp</result>
         <result name="success">login.jsp</result>
</action>

<action name="switchToFrench">
         <interceptor-ref name="i18n"/>
         <interceptor-ref name="basicStack"/>
         <result name="input">error.jsp</result>
         <result name="success">login.jsp</result>
</action>

现在,在语言切换后出现相同的页面 (login.jsp)。但是,我想返回用户在语言切换之前所在的页面。

提前致谢。

I am using struts2 and in my struts.xml I have written following code for locale switching -

<action name="switchToEnglish">
         <interceptor-ref name="i18n"/>
         <interceptor-ref name="basicStack"/>
         <result name="input">error.jsp</result>
         <result name="success">login.jsp</result>
</action>

<action name="switchToFrench">
         <interceptor-ref name="i18n"/>
         <interceptor-ref name="basicStack"/>
         <result name="input">error.jsp</result>
         <result name="success">login.jsp</result>
</action>

Now, after language switching same page (login.jsp) appears. But, I want to return on the page where user was before language switching.

Thanks in advance.

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

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

发布评论

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

评论(2

爱你不解释 2024-09-06 01:24:38

我也有同样的问题。我通过将页面名称传递给操作(通过 GET 或 POST)来解决它,然后我以这种方式在结果中使用它:

<action name="switchToEnglish">
     <interceptor-ref name="i18n"/>
     <interceptor-ref name="basicStack"/>
     <result name="input">error.jsp</result>
     <result name="success">%{currentPage}</result>
</action>

<action name="switchToFrench">
     <interceptor-ref name="i18n"/>
     <interceptor-ref name="basicStack"/>
     <result name="input">error.jsp</result>
     <result name="success">%{currentPage}</result>
</action>

不要忘记在操作类中为“currentPage”设置 getter/setter。

这不是最好的方法,但对我的应用程序来说还可以。

I had the same problem. I resolved it by passing the page name to the action(by GET or POST), then I use it in the result this way :

<action name="switchToEnglish">
     <interceptor-ref name="i18n"/>
     <interceptor-ref name="basicStack"/>
     <result name="input">error.jsp</result>
     <result name="success">%{currentPage}</result>
</action>

<action name="switchToFrench">
     <interceptor-ref name="i18n"/>
     <interceptor-ref name="basicStack"/>
     <result name="input">error.jsp</result>
     <result name="success">%{currentPage}</result>
</action>

Don't forget to set the getter/setter for "currentPage" in the action Class.

It's not the best way to do it but it was ok for my app.

淡看悲欢离合 2024-09-06 01:24:38

我还通过向 LocaleAction 发出 AJAX 请求来做到这一点,成功后,只需使用 jQuery 刷新页面,您将停留在区域设置更改之前的同一页面上。

脚本:

<script type="text/javascript">
$(document).ready(function(){

    $(".lang").click(function() {
        var id = $(this).attr("id");
        $.ajax({
            type: "POST",
            url: "locale.action?lang="+id,
            cache: false,
            success: function(){
                window.location.href='';
            }
        });
        return false;
    });
});
</script>

和链接:

       <span style="float: right;">
            <s:a id="ro" cssClass="lang">Română</s:a>
            •
            <s:a id="ru" cssClass="lang">Русский</s:a>
            •
            <s:a id="en" cssClass="lang">English</s:a>
        </span>

Also I have made this, with an AJAX request to the LocaleAction, on success, just refresh the page with jQuery and you will stay on the same page where you was before the locale change.

script:

<script type="text/javascript">
$(document).ready(function(){

    $(".lang").click(function() {
        var id = $(this).attr("id");
        $.ajax({
            type: "POST",
            url: "locale.action?lang="+id,
            cache: false,
            success: function(){
                window.location.href='';
            }
        });
        return false;
    });
});
</script>

And the links:

       <span style="float: right;">
            <s:a id="ro" cssClass="lang">Română</s:a>
            •
            <s:a id="ru" cssClass="lang">Русский</s:a>
            •
            <s:a id="en" cssClass="lang">English</s:a>
        </span>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文