使用jquery unobtrusive在客户端验证HttpPostedFileBase

时间:2016-02-07 10:14:31

标签: jquery asp.net-mvc file-upload unobtrusive-validation unobtrusive-javascript

我的网站上有jquery(原创,验证和不引人注意)。我已经扩展了一个在服务器端工作的验证属性,但我不能在我的生活中让它在客户端工作。我错过了什么?

我的模型看起来像这样:

[Display(Name = "UploadFile"), DataType(DataType.Upload)]
[ValidateFile]
public IEnumerable<HttpPostedFileBase> MyImage { get; set; }

我已将此属性扩展名添加到我的模型中:

public class ValidateFileAttribute : ValidationAttribute 
{
    public override bool IsValid(object value)
    {
        int MaxContentLength = 1024 * 1024 * 10; //10 MB
        string[] AllowedFileExtensions = new string[] { ".jpg", ".gif", ".png", ".pdf" };
        var files = value as IEnumerable<HttpPostedFileBase>;

        foreach (var file in files)
        {
            if (file == null)
            {
                return false;
            }
            else if (!AllowedFileExtensions.Contains(file.FileName.Substring(file.FileName.LastIndexOf('.'))))
            {
                ErrorMessage = Resources.ResourcesAdvert.AdvertUploadFileExtensionErrorShorter + string.Join(", ", AllowedFileExtensions);
                return false;
            }
            else if (file.ContentLength > MaxContentLength)
            {
                ErrorMessage = Resources.ResourcesAdvert.AdvertUploadFileTooBig + (MaxContentLength / 1024).ToString() + "MB";
                return false;
            }
            else
            {
                return true;
            }
        }
        return false;
    }
}

我有这样的观点:

@Html.LabelFor(x => x.MyImage)

<input type="file" name="MyImage[0]" id="MyImage1" />
<input type="file" name="MyImage[1]" id="MyImage2" />
<input type="file" name="MyImage[2]" id="MyImage3" />

@Html.ValidationMessageFor(x => x.MyImage)

我的控制器工作正常,如果图像有效,它可以上传图像。我有什么想法可以继续吗?

编辑:我还尝试使用this,但这对我的客户端也不起作用,我无法自定义错误消息。

1 个答案:

答案 0 :(得分:0)

由于没有答案我会分享一些信息以防其他人遇到同样的问题。

我最终通过@Stephen Muecke提供的链接(here)解决了这个问题。我的问题是没有正确配置javascript,因为我不知道在哪里放置每个变量。