我的页面上有一个 ASP 文件上传控件。 如何在客户端验证所选文件。验证规则:1.文件必须是JPEG,PNG,BMP或GIF。2. 文件大小必须在 25 KB 和 2 MB 之间。请帮忙。谢谢。
我尝试了以下代码来验证扩展
<asp:FileUpload ID="FileUpload2" runat="server"/>
<asp:CustomValidator ID="CustomValidator1" runat="server" ClientValidationFunction="ValidateFileUpload" ErrorMessage="Invalid file type. Only .gif, .jpg, .png, .bmp and .jpeg are allowed." ControlToValidate="FileUpload2" ValidationGroup="update"> </asp:CustomValidator>
<script language="javascript" type="text/javascript">
function ValidateFileUpload(Source, args) {
var fuData = document.getElementById('<%= fuData.ClientID %>');
var FileUploadPath = fuData.value;
if (FileUploadPath == '') {
// There is no file selected
args.IsValid = false;
}
else {
var Extension = FileUploadPath.substring(FileUploadPath.lastIndexOf('.') + 1).toLowerCase();
if (Extension == "jpg" || Extension == "jpeg" || Extension == "png" || Extension == "gif" || Extension == "bmp") {
args.IsValid = true; // Valid file type
}
else {
args.IsValid = false; // Not valid file type
}
}
}
</script>
您无法通过客户端脚本确定在文件输入元素中选择的文件的大小。 为了确定文件的大小,必须具有文件的读取访问权限。 正如你可能想象的那样,允许JavaScript读取计算机上的文件将是一个"非常糟糕的主意"。™
我经常看到这种类型的问题,并认为对文件输入元素的实际作用存在一些混淆。 当用户选择文件时,文件字节不会"加载"到此元素中,以便可供读取。 相反,输入指定对文件位置的引用,以便浏览器知道 - 当表单发布时 - 对文件进行编码并使用 POST 发送。 此过程是浏览器内部的,不会以脚本可以利用的方式向客户端公开。
如果需要执行文件大小验证,则应在有权访问实际文件字节的服务器上进行。 如果您担心人们用非常大的文件"淹没"您的网站,您可以通过配置 IIS 实例来指定允许的最大 POST 大小。
您可以试用 ajax 控制工具包。它对文件上传有自己的控制。它更酷
在现在使用的大多数浏览器中,您可以对文件大小进行客户端验证:https://stackoverflow.com/a/1832497/2705769