如何解决如何通过 JQuery Ajax POST 调用上传/发送文件作为电子邮件附件上传到 MVC 控制器?
我注意到除了 IE 之外的现代浏览器会在 Jquery 对象中显示一个假路径,这是一种安全保护,以避免服务器通过浏览器访问客户端物理驱动器。
我在这里和那里看到了一些其他使用 formData 的帖子。我确实认为它适用于文件或仅适用于文件。但我的情况是需要传递一些其他信息,如 ID 和几个字符串值以及上传到后端的文件。
我原来的实现是这样的:
Ajax 调用:
var emails = {
RequestId: requestId,ToEmails: toEmails,CcEmails: ccEmails,FileList: fileList
};
$.ajax({
url: '@Url.Action("SendEmails")',type: 'POST',data: JSON.stringify(emails),contentType: "application/json; charset=utf-8",dataType: "json",success: function (response) {
}
});
.Net Core MVC 控制器:
[HttpPost]
public bool SendEmails([FromBody]ToCcEmails emails)
{
}
复杂对象类型类:
public class ToCcEmails
{
public int RequestId { get; set; }
public string ToEmails { get; set; }
public string CcEmails { get; set; }
public List<string> FileList { get; set; }
}
我应该对我的 ajax 代码或什至 MVC 操作文件进行哪些更改,以使其与 formData 解决方案或任何其他解决方案正确配合?
谢谢。
解决方法
我确实认为它适用于文件或仅适用于文件。但我在一个 需要传递一些其他信息的情况,例如 ID 和 将文件上传到后端的几个字符串值。
如果你想用文件发布数据,你的模型似乎不正确,下面是一个工作演示:
型号:
public class ToCcEmails
{
public int RequestId { get; set; }
public string ToEmails { get; set; }
public string CcEmails { get; set; }
public List<IFormFile> FileList { get; set; }
}
查看:
<form>
<input type="text" name="RequestId" />
<input type="text" name="ToEmails" />
<input type="text" name="CcEmails" />
<input type="file" multiple name="FileList" />
</form>
@section Scripts
{
<script>
$("input[name='FileList']").change(function () {
var data = new FormData();
$("input[name='FileList']").each(function () {
var ReadyToUpload = $(this)[0].files;
if (ReadyToUpload.length > 0) {
$.each(ReadyToUpload,function (i,file) {
data.append("FileList",file);
});
}
});
$("form input[type='text']").each(function (x,y) {
data.append($(y).attr("name"),$(y).val());
});
$.ajax({
url: '@Url.Action("SendEmails")',type: 'POST',data: data,// contentType: "application/json; charset=utf-8",dataType: "json",processData: false,contentType: false,success: function (response) {
}
});
})
</script>
}
控制器:
[HttpPost]
public bool SendEmails([FromForm]ToCcEmails emails)
{
return true;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。