0

我继承了一个使用 Struts 1.2 开发的网站,我需要对其进行一些更新。对于其中一个更新,当用户单击按钮时,我需要根据从动态创建(使用 struts)下拉框中选择的值设置会话变量。我尝试完成此任务的方法是使用按钮的“onclick”属性来调用 JavaScript 函数,该函数利用 AJAX 对 struts Action 类进行异步调用。

我已经成功地实施了这个解决方案,但是,我遇到了一个只是偶尔发生的问题。在大多数情况下,当我单击按钮时,会话变量似乎设置正确。但是,有时会话变量没有被设置/重置。这个问题的零星性质是什么让我失望。看起来 AJAX 代码块正在被调用和处理(返回 readyState = 4 和 status = 200),但是没有输入 Java struts 逻辑。代码如下。

JavaScript AJAX 函数:

function createTaskOpp() {
var selectedOpp = document.getElementById("oppId");
var url="setTaskSessionOpportunity.do?opp=" + selectedOpp.value;
var ajaxRequest;

try
{
    // Opera 8.0+, Firefox, Safari
    ajaxRequest = new XMLHttpRequest();
}
catch (e)
{
    // Internet Explorer Browsers
    try
    {
        ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
    }
    catch (e)
    {
        try
        {
            ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
        } 
        catch (e)
        {
            // Something went wrong while trying to create our HTTP object. Resubmit the current page.
            alert("Browser Error. Error creating Request Object: " + e);
            window.location ="taskConfiguration.do";
        }
    }
}
ajaxRequest.open("GET", url, true);
ajaxRequest.onreadystatechange = function() {

if (ajaxRequest.readyState == 4)
{
    if (ajaxRequest.status == 200) 
    {
        window.location ="saveTask.do";
    }

    else  {
        window.location ="taskConfiguration.do";
    }
}
};
ajaxRequest.send(null); }

Struts 动作:

public class SetTaskSessionOpportunityAction extends Action {
public ActionForward execute( ActionMapping mapping, ActionForm form,
        HttpServletRequest request, HttpServletResponse response)
{
    System.out.println("*****************");
    System.out.println("In SetTaskOpp AJAX -Beginning");
    HttpSession session = request.getSession();
    String taskOpp = request.getParameter("opp");
    session.setAttribute("task_opportunity", taskOpp);
    ActionForward actionForward = new ActionForward("/viewTask.jsp");
    return actionForward;
}

}

谢谢您的帮助!-乔什

4

1 回答 1

2

问题解决了。事实证明这是 AJAX 请求的浏览器缓存问题。IE(我的测试环境)自动缓存 AJAX 请求。我通过添加以下代码行更正了该问题:

response.setHeader("Cache-Control", "no-cache"); 
于 2010-10-11T08:57:19.443 回答