ASP.NET MVC 4 C# HttpPostedFileBase, EntityValidationErrors 保存到数据库中。

14 浏览
0 Comments

ASP.NET MVC 4 C# HttpPostedFileBase, EntityValidationErrors 保存到数据库中。

在我的数据库中,My FileLocation是VarChar(Max)类型的,我不确定是什么导致了EntityValidationErrors - System.Data.Entity.Validation.DbEntityValidationException:一个或多个实体的验证失败。当db.SaveChanges()函数运行时会发生此错误;

模型:

public Assignment()

{

this.CourseAvailables = new HashSet();

}

public string AssignmentID { get; set; }

public Nullable SubmissionDate { get; set; }

public string Status { get; set; }

public Nullable Mark { get; set; }

public string Comments { get; set; }

public string FileLocation { get; set; }

public virtual ICollection CourseAvailables { get; set; }

控制器:

[HttpPost]

public ActionResult Create(Assignment assignment)

{

if (ModelState.IsValid)

{

if (Request.Files.Count > 0)

{

HttpPostedFileBase assignmentFile = Request.Files[0];

if (assignmentFile.ContentLength > 0)

{

var fileName = Path.GetFileName(assignmentFile.FileName);

assignment.FileLocation = Path.Combine(Server.MapPath("~/Content/Image"), fileName);

assignmentFile.SaveAs(assignment.FileLocation);

}

}

db.Assignments.Add(assignment);

db.SaveChanges();

return RedirectToAction("Index");

}

return View(assignment);

}

视图:

<% using (Html.BeginForm("Create", "Assignment", FormMethod.Post, new { enctype = "multipart/form-data" }))

<%: Html.TextBoxFor(model => model.FileLocation, new { type="file"})%>

<%: Html.ValidationMessageFor(model => model.FileLocation) %>

0
0 Comments

ASP.NET MVC 4 C# HttpPostedFileBase, EntityValidationErrors Save into DB

问题出现的原因:

问题出现的原因可能是数据库中其他列的配置问题。如果数据库中的Status、Comments和Mark列的数据类型和/或数据长度没有正确设置,可能会导致出现问题。

解决方法:

解决方法是检查数据库,确保其他列的配置适当。需要确保Status、Comments和Mark列的数据类型和/或数据长度在数据库中正确设置。

代码示例:

// 获取上传的文件
HttpPostedFileBase file = Request.Files["file"];
// 检查文件是否为空
if (file != null && file.ContentLength > 0)
{
    // 保存文件到服务器
    string fileName = Path.GetFileName(file.FileName);
    string filePath = Path.Combine(Server.MapPath("~/Uploads"), fileName);
    file.SaveAs(filePath);
    // 将文件路径保存到数据库
    using (var db = new YourDbContext())
    {
        var entity = new YourEntity();
        // 设置其他属性的值
        entity.Status = "InProgress";
        entity.Comments = "Some comments";
        entity.Mark = 5;
        // 设置文件路径属性的值
        entity.FilePath = filePath;
        // 将实体添加到数据库上下文
        db.YourEntities.Add(entity);
        try
        {
            // 尝试保存更改到数据库
            db.SaveChanges();
        }
        catch (DbEntityValidationException ex)
        {
            // 如果保存失败,处理实体验证错误
            foreach (var validationErrors in ex.EntityValidationErrors)
            {
                foreach (var validationError in validationErrors.ValidationErrors)
                {
                    Console.WriteLine("Property: " + validationError.PropertyName + " Error: " + validationError.ErrorMessage);
                }
            }
        }
    }
}

以上代码示例演示了在ASP.NET MVC 4中使用C#的HttpPostedFileBase类将文件保存到服务器并将文件路径保存到数据库的过程。在保存更改到数据库时,如果发生实体验证错误,可以使用EntityValidationErrors来处理错误并输出错误消息。

通过检查数据库配置,确保其他列的数据类型和/或数据长度正确设置,可以避免出现问题。

0
0 Comments

这个问题的出现的原因是试图保存的数据超过了所定义的列的最大长度。虽然问题没有明确提到哪一列的数据将被截断,但可以推断出数据太长了,超过了最大长度。

解决这个问题的方法是检查数据库表中相关列的定义,并确保将要保存的数据长度不超过最大长度。如果确定数据长度没有超过最大长度,可以考虑调整列的定义,将最大长度增加到可以容纳所需的数据长度。

以下是一种可能的解决方法的示例代码:

public ActionResult SaveData(HttpPostedFileBase file)
{
    if (file != null && file.ContentLength > 0)
    {
        using (var reader = new StreamReader(file.InputStream))
        {
            string data = reader.ReadToEnd();
            
            // 检查数据长度是否超过最大长度
            if (data.Length > MAX_LENGTH)
            {
                // 数据超过最大长度,进行适当的处理
                // ...
            }
            else
            {
                // 保存数据到数据库
                using (var db = new YourDbContext())
                {
                    // 将数据保存到数据库表中
                    db.YourTable.Add(new YourEntity { Data = data });
                    db.SaveChanges();
                }
                
                // 数据保存成功
                // ...
            }
        }
    }
    
    // ...
}

在上面的示例代码中,我们首先检查数据的长度是否超过了最大长度。如果超过了最大长度,可以根据需要进行适当的处理,例如截断数据或给出错误提示。如果数据长度没有超过最大长度,我们使用Entity Framework将数据保存到数据库表中。

需要注意的是,示例代码中的`YourDbContext`和`YourTable`是根据具体情况进行替换的。此外,还需要根据实际需要调整最大长度的值和其他相关的逻辑。

通过以上的解决方法,我们可以解决ASP.NET MVC 4中使用C#处理`HttpPostedFileBase`对象时可能出现的数据超过最大长度的问题,并将保存数据到数据库中的实体验证错误(`EntityValidationErrors`)避免进一步扩大。

0