ASP页面没有收到POST参数

时间:2009-12-10 18:26:28

标签: post asp-classic parameters input html-form

我在Classic ASP中编写一个小应用程序。我有一个页面,其中有一个表单,发布到第二页。表单的POST包括文件上传,因此需要POST方法。

第二页虽然没有看到第一页发送的任何字段。调用Request("param")Request.Form("param")都只返回空字符串。

如果我将我的表单上的方法从POST切换到GET(带有 NO 其他更改),那么接收页面会正确选择这些值,当然我无法上传文件,这是本申请的重要组成部分。

在GET模式下,参数全部按预期放在网址上。在POST模式下,我启动了FireBug,并检查了我的请求的POST数据。原始表单 IS 发送请求中的所有值(它们按预期显示在FireBug中),因此问题似乎出现在接收页面的末尾。

表单是通过代码提交的,从带有onclick="javascript:saveMinutes();"

的按钮调用

我的表单和saveMinutes()函数声明如下:

<form id="frmMinutes" enctype="multipart/form-data" method="post" action="saveminutes.asp">
<table id="tblMinutes" style="width: 100%;">
    <tr>
        <td>
            <select id="selYear" name="year" size="13" onclick="javascript:setDatePickerRange(); checkForMinutes();">
                <%For lc = Year(Now) To getMinutesFirstYear() Step - 1%>
                    <option value="<%=lc%>" <%If lc = Year(Now) Then%>selected="selected"<%End If%>><%=lc%></option>
                <%Next%>
            </select>
        </td>
        <td>
            <select id="selMonth" name="month" size="13" onclick="javascript:setDatePickerRange(); checkForMinutes();">
                <%For lc = 1 To 12%>
                    <option value="<%=lc%>" <%If lc = Month(Now) Then%>selected="selected"<%End If%>"><%=MonthName(lc)%></option>
                <%Next%>
            </select>
        </td>
        <td style="width: 100%; padding-left: 20px;">
                <table id="enterMinutes" style="width: 100%">
                    <tr>
                        <th>Topic:</th>
                        <td><input id="topic" name="topic" type="text" maxlength="100" field="topic" /></td>
                    </tr>
                     <tr>
                        <th>Presenter:</th>
                        <td><input id="presenter" name="presenter" type="text" maxlength="100" field="presenter" /></td>
                    </tr>
                     <tr>
                        <th>Date:</th>
                        <td><input id="mtgdate" name="mtgdate" type="text" maxlength="10" class="datepick" field="mtgdate" readonly="readonly" /></td>
                    </tr>
                     <tr>
                        <th style="vertical-align: top;">Files:</th>
                        <td style="text-align: left;">
                            <input id="file0" name="file0" type="file" size="35" /><span class="redEmphasis" style="margin: 0px 10px 0px 10px;">(.doc or .docx)</span><input type="button" value="+" onclick="javascript:addFileUpload();" />
                        </td>
                    </tr>
                     <tr>
                        <th style="vertical-align: top;"></th>
                        <td style="text-align: left; padding: 10px 0px 10px 0px;">
                            <input type="button" style="width: 100%" value="update minutes" onclick="javascript:saveMinutes();" />
                        </td>
                    </tr>
               </table>
               <span id="warnexist" class="redEmphasis" style="display: none;">The selected month already has associated minutes (). doc files take precedence over docx.</span>
        </td>
    </tr>
</table>
</form>

saveMinutes():

function saveMinutes() {
    if($('form#frmMinutes input[type=text]').filter(function () { return $(this).val() == '' }).length > 0) {
        alert('Please enter all fields.');
        return;
    }

    if ($('form#frmMinutes input#file0').filter(function () { return !$(this).val().match(/.*\.docx?$/i) }).length > 0) {
        alert('First file must be doc or docx.');
        return;
    }

    $('form#frmMinutes input[type=file]').filter(function () { return $(this).val() == '' }).next().remove();
    $('form#frmMinutes input[type=file]').filter(function () { return $(this).val() == '' }).remove();

    removeDupeFiles();

    // reindex file inputs after removing emptys/dupes
    var fs = $('form#frmMinutes input[type=file]:gt(0)');
    for (lc = 1; lc <= fs.length;  lc++) {
        var fid = 'file' + new String(lc);
        $(fs[lc-1]).attr('id', fid).attr('name', fid);
    }

    $('form#frmMinutes')[0].submit();
}

1 个答案:

答案 0 :(得分:5)

当您的from编码为multipart时,您无法将POST值作为普通旧参数获取。它们只是多部分表单的附加部分。

要在ASP中检索上传的文件,通常需要遍历各个部分并检查每个部分以查看它是否是文件(如果是,则保存)。要获取字段值,您必须添加到该循环以检查每个部分以查看它是否具有您的某个字段值的名称,然后检索该值。这在纯ASP代码中很难做到,因此很多人使用某种类型的文件上传组件,在这种情况下,字段值的检索将取决于组件。

但基本的信息是:无论你正在检索文件的表格进行解析,你都必须做同样的事情来检索字段值。