我的页面上有一个asp fileupload控件。如何在客户端验证所选文件。
验证规则:
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>
答案 0 :(得分:6)
您无法通过客户端脚本确定文件输入元素中选定文件的大小。为了确定文件的大小,必须具有对文件的读访问权。正如您可能想象的那样,允许JavaScript读取您计算机上的文件将是一个“非常糟糕的主意。”™
我经常看到这类问题,并且认为文件输入元素实际上有什么困惑。当用户选择文件时,文件字节不会“加载”到该元素中,使得它们可供读取。相反,输入指定文件位置的引用,以便浏览器知道 - 何时发布表单 - 对文件进行编码并使用POST发送它。此过程是浏览器的内部过程,不会以脚本可以利用的方式向客户端公开。
如果需要进行文件大小验证,则应在可以访问实际文件字节的服务器上进行。如果您担心人们使用非常大的文件“泛滥”您的站点,您可以通过配置IIS实例来指定允许的最大POST大小。
答案 1 :(得分:2)
您可以试用ajax控制工具包。它有自己的文件上传控件。它更酷了
答案 2 :(得分:0)
在目前使用的大多数浏览器中,您可以对文件大小进行客户端验证: https://stackoverflow.com/a/1832497/2705769