上传的文件未发布

时间:2012-05-16 17:48:38

标签: c# javascript forms post file-upload

我正在使用下面的上传表单发布到使用以下代码处理文件的页面。但是,该文件未显示。没有发布文件,我得到了0分。我错过了表格帖子中的内容吗?我知道上传文件时必须使用的内容相当具体。我在下面还提供了更多信息。

表格

<form id="importform" method="POST" target="uploadframe" enctype="multipart/form-data" action="AJAX/Import_Subprocess_Content/RAC_Connolly_ImportSession.aspx">
                                        <input type="file" id="importfile" onchange="fileselected()"/>
                                        <input type="button" value="Import File" onclick="uploadfile();" />
                                    </form>

服务器端代码

  protected void Page_Load()
        {
            Response.Write(Request.Files.Count);
        }

更多信息

表单使用.submit()

通过javascript发布

文件输入为visibility:hidden

按钮首先调用文件输入的click()

onchange文件输入调用表单的submit()

更新:尝试删除隐藏属性,但未解决问题。

2 个答案:

答案 0 :(得分:0)

您实际上没有进行文件上传。您需要将代码添加到“导入文件”按钮。

此代码查看文件字段,检查它是否有文件,然后说只能上传CSV的类型。然后,它将文件保存到Web服务器上的/ datafiles文件夹中。

protected void btnUpload_Click(object sender, EventArgs e)
    {
        if (file.HasFile)
        {
            try
            {
                if (file.PostedFile.ContentType == "application/octet-stream")
                {
                    string filename = Path.GetFileName(file.FileName);
                    file.SaveAs(Server.MapPath("~/datafiles/") + filename);
                    lblStatus.ForeColor = Color.Green;
                    lblStatus.Text = "Upload status: File uploaded!";
                }
                else
                {
                    lblStatus.ForeColor = Color.Red;
                    lblStatus.Text = "Upload status: Only .CSV files are accepted! This is a " + file.PostedFile.ContentType + " file";
                }
            }
            catch (Exception ex)
            {
                lblStatus.ForeColor = Color.Red;
                lblStatus.Text = "Upload status: The file could not be uploaded. The following error occured: " + ex.Message;
            }
        }
    }

答案 1 :(得分:0)

文件需要上传名称属性。当给出name属性时,IE7会出现另一个问题,即在上传文件时无法通过javascript发布表单。不得不默认使用提交按钮而不是onchange事件。