尝试上传时控制器操作未从视图中抓取文件
Controller action not grabbing file from view when attempting to upload
我正在尝试将 .csv 文件上传到 SQL 数据库,但控制器操作似乎根本没有抓取该文件。看看代码,我肯定少了一块:
查看:
@using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post))
{
<table style="margin-top: 150px;">
<tr>
<td>
<label for="csvFile">Filename:</label>
</td>
<td>
<input type="file" name="csvFile" id="csvFile"/>
</td>
<td><input type="submit" value="Upload"/></td>
</tr>
</table>
}
控制器:
[HttpPost]
public JsonResult UploadValidationTable(HttpPostedFileBase csvFile)
{
var inputFileDescription = new CsvFileDescription
{
SeparatorChar = ',',
FirstLineHasColumnNames = true
};
var cc = new CsvContext();
var filePath = uploadFile(csvFile.InputStream);
var model = cc.Read<OutstandingCreditCsv>(filePath, inputFileDescription);
try
{
var entity = new OutstandingCreditCsv();
foreach (var item in model)
{
entity.PoNumber = item.PoNumber;
entity.CreditInvoiceDate = item.CreditInvoiceDate;
entity.CreditInvoiceNumber = item.CreditInvoiceNumber;
entity.CreditInvoiceAmount = item.CreditInvoiceAmount;
}
}
catch(LINQtoCSVException ex)
{
}
return Json(model, "text/json");
}
csvFile 只是显示为 null,不知道会发生什么,因为它在视图中被命名并且我有围绕它的 post 方法。它一直下降到 var filePath = uploadFile(csvFile.InputStream);
然后中断,因为该方法试图传递空值。谢谢!
我认为您需要将 enctype='multipart/form-data'
添加到您的 <form>
using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post,
new { enctype = "multipart/form-data" }))
您需要在表单声明中添加以下内容:
@using (Html.BeginForm("UploadValidationTable", "Home", null,FormMethod.Post, new { enctype = "multipart/form-data" }))
您需要更改表单声明。尝试将 enctype = "multipart/form-data" 添加到表单声明中。
@using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post, new { enctype = "multipart/form-data"}))
前阵子我在尝试使用 MVC 将文件上传到数据库时遇到了这个问题,当时我使用的是脚手架视图(因此它也传回了一个带有表单的对象),所以它可能有点不同。
在您的 HTML.BeginForm() 调用中,您需要添加属性 enctype="multipart/form-data"
@using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post, new {enctype="multipart/form-data"}))
我正在尝试将 .csv 文件上传到 SQL 数据库,但控制器操作似乎根本没有抓取该文件。看看代码,我肯定少了一块:
查看:
@using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post))
{
<table style="margin-top: 150px;">
<tr>
<td>
<label for="csvFile">Filename:</label>
</td>
<td>
<input type="file" name="csvFile" id="csvFile"/>
</td>
<td><input type="submit" value="Upload"/></td>
</tr>
</table>
}
控制器:
[HttpPost]
public JsonResult UploadValidationTable(HttpPostedFileBase csvFile)
{
var inputFileDescription = new CsvFileDescription
{
SeparatorChar = ',',
FirstLineHasColumnNames = true
};
var cc = new CsvContext();
var filePath = uploadFile(csvFile.InputStream);
var model = cc.Read<OutstandingCreditCsv>(filePath, inputFileDescription);
try
{
var entity = new OutstandingCreditCsv();
foreach (var item in model)
{
entity.PoNumber = item.PoNumber;
entity.CreditInvoiceDate = item.CreditInvoiceDate;
entity.CreditInvoiceNumber = item.CreditInvoiceNumber;
entity.CreditInvoiceAmount = item.CreditInvoiceAmount;
}
}
catch(LINQtoCSVException ex)
{
}
return Json(model, "text/json");
}
csvFile 只是显示为 null,不知道会发生什么,因为它在视图中被命名并且我有围绕它的 post 方法。它一直下降到 var filePath = uploadFile(csvFile.InputStream);
然后中断,因为该方法试图传递空值。谢谢!
我认为您需要将 enctype='multipart/form-data'
添加到您的 <form>
using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post,
new { enctype = "multipart/form-data" }))
您需要在表单声明中添加以下内容:
@using (Html.BeginForm("UploadValidationTable", "Home", null,FormMethod.Post, new { enctype = "multipart/form-data" }))
您需要更改表单声明。尝试将 enctype = "multipart/form-data" 添加到表单声明中。
@using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post, new { enctype = "multipart/form-data"}))
前阵子我在尝试使用 MVC 将文件上传到数据库时遇到了这个问题,当时我使用的是脚手架视图(因此它也传回了一个带有表单的对象),所以它可能有点不同。
在您的 HTML.BeginForm() 调用中,您需要添加属性 enctype="multipart/form-data"
@using (Html.BeginForm("UploadValidationTable", "Home", FormMethod.Post, new {enctype="multipart/form-data"}))