onclick 多次存储相同的值
Onclick storing same value multiple times
考虑以下代码片段
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Create(MyViewModel viewModel)
{
if (ModelState.IsValid)
{
//map properties here
using (var context = new MyEntities())
{
context.Users.Add(user);
context.SaveChanges();
}
if (Request.Files.Count > 0)
{
foreach (string fileName in Request.Files)
{
HttpPostedFileBase file = Request.Files[fileName];
if (file != null && file.ContentLength > 0)
{
//do checks and upload file here
}
}
}
}
return RedirectToAction("Index", "Home");
}
表单可以单独提交,也可以与文件一起提交,然后上传到服务器。现在我的问题是,如果我提交的表格没有任何文件或只有一个文件,那么一切都会按预期进行。但是,用户一次可以上传多个文件,这就是问题所在。文件已上传,但我在数据库中获得了该特定表单的多个条目。例如,如果用户上传三个文件,我将在数据库中得到三个完全相同的条目。
所以我的问题是如何解决这个问题?
在客户端,我使用 DropZoneJs
并将方法调用为
<script>
Dropzone.autoDiscover = false;
var myDropZone = new Dropzone("#dzUpload", {
url: "/Home/Create",
autoProcessQueue: false,
previewsContainer: ".preview",
});
$("#submit-all").attr("type", "button").on('click', function (e) {
e.preventDefault();
e.stopPropagation();
if (myDropZone.getQueuedFiles().length > 0) {
myDropZone.options.autoProcessQueue = true;
myDropZone.processQueue();
}
else {
$("#dzUpload").submit();
}
});
</script>
我也遇到了 问题,但我还是遇到了同样的问题
uploadMultiple 选项似乎会改变行为,因此只向服务器发送一个请求。
var myDropZone = new Dropzone("#dzUpload", {
url: "/Home/Create",
autoProcessQueue: false,
previewsContainer: ".preview",
uploadMultiple: true,
});
所以如果我是对的,插件会 post 你放入插件的每个文件的表单,对吗?一种方法是生成一个 GUID 并将其维护在您的表单隐藏输入中。所以每次你的插件 posts 它也会 post 这个 GUID。因此,将您的插入语句更改为基于 Guid 的更新插入(更新或插入)。您还必须将此 GUID 与其他数据一起保存。
所以每次你打算插入时检查 GUID 是否已经存在如果是则更新它否则插入新记录。
考虑以下代码片段
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Create(MyViewModel viewModel)
{
if (ModelState.IsValid)
{
//map properties here
using (var context = new MyEntities())
{
context.Users.Add(user);
context.SaveChanges();
}
if (Request.Files.Count > 0)
{
foreach (string fileName in Request.Files)
{
HttpPostedFileBase file = Request.Files[fileName];
if (file != null && file.ContentLength > 0)
{
//do checks and upload file here
}
}
}
}
return RedirectToAction("Index", "Home");
}
表单可以单独提交,也可以与文件一起提交,然后上传到服务器。现在我的问题是,如果我提交的表格没有任何文件或只有一个文件,那么一切都会按预期进行。但是,用户一次可以上传多个文件,这就是问题所在。文件已上传,但我在数据库中获得了该特定表单的多个条目。例如,如果用户上传三个文件,我将在数据库中得到三个完全相同的条目。
所以我的问题是如何解决这个问题?
在客户端,我使用 DropZoneJs
并将方法调用为
<script>
Dropzone.autoDiscover = false;
var myDropZone = new Dropzone("#dzUpload", {
url: "/Home/Create",
autoProcessQueue: false,
previewsContainer: ".preview",
});
$("#submit-all").attr("type", "button").on('click', function (e) {
e.preventDefault();
e.stopPropagation();
if (myDropZone.getQueuedFiles().length > 0) {
myDropZone.options.autoProcessQueue = true;
myDropZone.processQueue();
}
else {
$("#dzUpload").submit();
}
});
</script>
我也遇到了
uploadMultiple 选项似乎会改变行为,因此只向服务器发送一个请求。
var myDropZone = new Dropzone("#dzUpload", {
url: "/Home/Create",
autoProcessQueue: false,
previewsContainer: ".preview",
uploadMultiple: true,
});
所以如果我是对的,插件会 post 你放入插件的每个文件的表单,对吗?一种方法是生成一个 GUID 并将其维护在您的表单隐藏输入中。所以每次你的插件 posts 它也会 post 这个 GUID。因此,将您的插入语句更改为基于 Guid 的更新插入(更新或插入)。您还必须将此 GUID 与其他数据一起保存。
所以每次你打算插入时检查 GUID 是否已经存在如果是则更新它否则插入新记录。