-2

我尝试通过使用 JMetter 提交表单(提交 100 个数据)来测试我的保存功能。在我的函数中,首先我将数据保存到数据库中。但是因为有太多重复保存的数据,我试着只写数据。我明白了,当我捕捉到 JMetter 提交的数据时,重复的数据就来了。我想问一下,为什么提交的数据是重复的,而当我使用wireshark检查提交的请求(发布)数据时,JMetter没有发送重复的数据。这意味着问题出在struts上。这个怎么解决,谢谢。

动作类中的函数代码以显示表单

public String renderAddMaintenanceItemForm(){
    maintenanceItem = new MaintenanceItemDto();
    return SUCCESS;
}

jsp表单代码

<%@ taglib prefix="s" uri="/struts-tags"%>
<script type="text/javascript"> 
jQuery(document).ready(function() { 
    jQuery("#frmAddMaintenanceItem").validate({
        submitHandler: function(form) {
            return postForm(form, "savemaintenanceitem", "listmaintenanceitem", true);
        }
    });
});
</script>

<h4 class="widgettitle nomargin shadowed">Add Maintenance Item</h4>
<div class="widgetcontent bordered shadowed nopadding">
<form id="frmAddMaintenanceItem" class="stdform stdform2">   
    <s:hidden name="maintenanceItem.id" value="%{maintenanceItem.id}"/> 
    <s:if test="maintenanceItem.criteria == 'perma'">
        <s:hidden name="maintenanceItem.criteria" value="%{maintenanceItem.criteria}"/> 
        <p>
            <label>Item Name</label>
            <span class="field">
                <s:textfield name="maintenanceItem.name" value="%{maintenanceItem.name}" cssClass='input-xlarge required chardigit' minlength="5" maxlength="50"/>
            </span>
            </p>
    </s:if>
    <s:else>    
            <p>
                <label>Tipe</label>
                <span class="field">
                    <select name="maintenanceItem.criteria" class="uniformselect required">
                        <option>Select</option>
                            <option value='event' <s:if test="maintenanceItem.criteria == 'event'">selected="selected"</s:if>>
                                Event
                            </option>
                            <option value='time' <s:if test="maintenanceItem.criteria == 'time'">selected="selected"</s:if>>
                                Time
                            </option>
                    </select>
                </span>
            </p>
            <p>
                <label>Item Name</label>
                <span class="field">
                    <s:textfield name="maintenanceItem.name" value="%{maintenanceItem.name}" cssClass='input-xlarge required chardigit' minlength="5" maxlength="50"/>
                </span>
            </p>
            <p>
                <label>Normal Treshold (KM)</label>
                <span class="field"><s:textfield name="maintenanceItem.normalTreshold" value="%{maintenanceItem.normalTreshold}" cssClass="input-xxlarge required"/></span>
            </p>
            <p>
                <label>Max Treshold (KM)</label>
                <span class="field"><s:textfield name="maintenanceItem.maxTreshold" value="%{maintenanceItem.maxTreshold}" cssClass="input-xxlarge required"/></span>
            </p>
    </s:else>
    <p>
        <label>Note</label>
        <span class="field"><s:textfield name="maintenanceItem.note" value="%{maintenanceItem.note}" cssClass="input-xxlarge required"/></span>
    </p>
    <p class="stdformbutton">
        <button class="btn btn-primary">Submit </button>
        <button type="reset" class="btn">Reset </button>
    </p>
</form>
</div>

这是保存用户输入的功能(在这种情况下,我只是将其写入控制台)

public String saveMaintenanceItem(){
    System.out.println(maintenanceItem.getName());
    /*messageDto = carService.saveMaintenanceItem(maintenanceItem);
    actionStatus = messageDto.getResult();
    SessionManager.serviceReturnToSession(session(), messageDto);*/
    return SUCCESS;
}

当我检查时,就像 jmetter 忽略了表单上的 javascript。Jmetter 直接将数据发布到动作类。这样对吗?而且我仍然很困惑为什么它仍然会得到重复的数据。

4

1 回答 1

0

似乎在名为 postForm 的 javascript 函数中,还有另一个表单提交。这可能会导致双重表单提交。如果您找不到问题,请剪切 jsp 页面块的部分并检查并提交给操作类。

于 2013-03-11T09:39:29.833 回答